

Author: Francesco Diotalevi, Maurizio Casti

Company: Istituto Italiano di Tecnologia

| History: | History:                        |                        |                                                                                                                                                                                                                                                                                               |  |  |  |  |
|----------|---------------------------------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Revision | Date                            | Author                 | Description                                                                                                                                                                                                                                                                                   |  |  |  |  |
| 1.0      | September 19 <sup>th</sup> 2016 | Francesco<br>Diotalevi | First Release (DRAFT)                                                                                                                                                                                                                                                                         |  |  |  |  |
| 1.1      | June 14 <sup>th</sup> 2017      | Francesco<br>Diotalevi | Modified the AXIstream module and added some debug ports. Added Reset_DMA_stream bit into CTRL_REG.                                                                                                                                                                                           |  |  |  |  |
| 2.0      | November 15 <sup>th</sup> 2017  | Francesco<br>Diotalevi | Bug fixed for the HSSAER Channel Enable. Added AUX Threshold Error register and AUX Rx Counter registers. Some Fixes in HDL code.                                                                                                                                                             |  |  |  |  |
| 2.1      | June 15 <sup>th</sup> 2018      | Francesco<br>Diotalevi | Enlarged to 24 the SSAER data transfer. Different header coding.                                                                                                                                                                                                                              |  |  |  |  |
| 3.0      | August 9 <sup>th</sup> 2018     | Maurizio<br>Casti      | Added the SpiNNlink interface capability                                                                                                                                                                                                                                                      |  |  |  |  |
| 3.1      | August 24 <sup>th</sup> 2018    | Maurizio<br>Casti      | Added the START/STOP and Data Mask Feature to SpiNNlink                                                                                                                                                                                                                                       |  |  |  |  |
| 3.2      | October 24 <sup>th</sup> 2018   | Francesco<br>Diotalevi | Splitted FlushFifos in FlushRXFifo and FlushTXFifos. Modifications in axistream module to premature end a burst transfer. Added register that counts data in AXI stream bus. Modified reset value of RX PAER Configuration register (RX_PAER_CFNG_REG). Enlarged DMA length field to 16 bits. |  |  |  |  |
| 3.3      | October 30 <sup>th</sup> 2018   | Francesco<br>Diotalevi | DMA register (DMA_REG) has thi bit 0 fixed to 0. It can be written only with even values.                                                                                                                                                                                                     |  |  |  |  |
| 3.4      | November 16 <sup>th</sup> 2018  | Maurizio<br>Casti      | Absolute Timing Feature for Transmission; "Force Stop" command for SpiNNaker                                                                                                                                                                                                                  |  |  |  |  |



### Contents

| нри со      | RE 3.4 (REV 15) - USER GUIDE                                     | 1       |
|-------------|------------------------------------------------------------------|---------|
| GLOSSA      | NRY                                                              | 4       |
| HPUCO       | RE IMPLEMENTATION PARAMETERS                                     | 4       |
| INTRO       | DUCTION                                                          | 5       |
| 1 HP        | UCORE BLOCK DIAGRAM                                              | 7       |
| 1.1         | UNDERSTANDING THE HPU CORE IN SYNTHTACTAER APPLICATION.          | 8       |
| 2 HP        | UCORE INTERNAL REGISTERS                                         | 10      |
| 2.1         | CONTROL REGISTER (CTRL_REG)                                      | 12      |
| 2.2         | LOOPBACK LR CONFIGURATION REGISTER (LPBK_LR_CNFG_REG)            | 13      |
| 2.3         | RX DATA BUFFER REGISTER (RXDATA_REG)                             | 14      |
| 2.4         | RX TIME BUFFER REGISTER (RXTIME_REG)                             | 15      |
| 2.5         | TX DATA BUFFER REGISTER (TXDATA_REG)                             | 17      |
| 2.6         | DMA register (DMA_REG)                                           | 18      |
| 2.7         | RAW STATUS REGISTER (STAT_RAW_REG)                               | 19      |
| 2.8         | IRQ REGISTER (IRQ_REG)                                           |         |
| 2.9         | Mask Register (MSK_REG)                                          | 23      |
| 2.10        | WRAPPING TIMESTAMP REGISTER (WRAPTIMESTAMP_REG)                  | 24      |
| 2.11        | HSSAER STATUS REGISTER (HSSAER_STAT_REG)                         | 25      |
| 2.12        | HSSAER RX Error register (HSSAER_RX_ERR_REG)                     | 26      |
| 2.13        | HSSAER RX MSK REGISTER (HSSAER_RX_MSK_REG)                       |         |
| 2.14        | RX CONTROL REGISTER (RX_CTRL_REG)                                | 28      |
| 2.15        | TX CONTROL REGISTER (TX_CTRL_REG)                                | 29      |
| 2.16        | RX PAER CONFIGURATION REGISTER (RX_PAER_CFNG_REG)                | 31      |
| 2.17        | TX PAER Configuration register (TX_PAER_CFNG_REG)                | 32      |
| 2.18        | IP CONFIGURATION REGISTER (IP_CFNG_REG)                          | 33      |
| 2.19        | FIFO THRESHOLD REGISTER (FIFO_THRSH_REG)                         | 34      |
| 2.20        | LOOPBACK AUX CONFIGURATION (LPBK_AUX_CNFG_REG)                   | 35      |
| 2.21        | Identification register (ID_REG)                                 | 36      |
| 2.22        | AUXILIARY RX CONTROL REGISTER (AUX_RX_CTRL_REG)                  | 37      |
| 2.23        | HSSAER AUX RX Error register (HSSAER_AUX_RX_ERR_REG)             | 38      |
| 2.24        | HSSAER AUX RX MSK REGISTER (HSSAER_AUX_RX_MSK_REG)               | 39      |
| 2.25        | AUX ERROR COUNTER THRESHOLD REGISTER (HSSAER_AUX_RX_ERR_THR_REG) | 40      |
| 2.26        | AUX ERROR COUNTER CH0 REGISTER (HSSAER_AUX_RX_ERR_CH0_REG)       | 41      |
| 2.27        | AUX ERROR COUNTER CH1 REGISTER (HSSAER_AUX_RX_ERR_CH1_REG)       | 42      |
| 2.28        | AUX ERROR COUNTER CH2 REGISTER (HSSAER_AUX_RX_ERR_CH2_REG)       | 43      |
| 2.29        | AUX ERROR COUNTER CH3 REGISTER (HSSAER_AUX_RX_ERR_CH3_REG)       | 44      |
| 2.30        | SPINNLINK START COMMAND KEY (SPNN_START_KEY_REG)                 | 45      |
| 2.31        | SPINNLINK STOP COMMAND KEY (SPNN_STOP_KEY_REG)                   | 46      |
| 2.32        | SPINNLINK TX DATA MASK (SPNN_TX_MASK_REG)                        |         |
| Revision: B | EDL Electronic Design Labo                                       | oratory |



| 4.1 | L AXISTREAM ASM                               | 55 |
|-----|-----------------------------------------------|----|
| 4   | APPENDIXES                                    | 55 |
| 3 I | REFERENCES                                    | 54 |
| 2.3 | 38 TDATA COUNTER REGISTER (TDATACNT_REG)      | 53 |
| 2.3 | TLAST COUNTER REGISTER (TLASTCNT_REG)         | 52 |
| 2.3 | 36 TLAST TIMEOUT REGISTER (TLASTTO_REG)       | 51 |
| 2.3 | SPINNLINK STATUS REGISTER (SPNN_STATUS_REG)   | 50 |
| 2.3 | 34 SPINNLINK CONTROL REGISTER (SPNN_CTRL_REG) | 49 |
| 2.3 | 33 SPINNLINK RX DATA MASK (SPNN_RX_MASK_REG)  | 48 |



## **Glossary**

| Acronym | Meaning       |  |  |  |  |  |  |
|---------|---------------|--|--|--|--|--|--|
| TBD     | To Be Defined |  |  |  |  |  |  |
| TBT     | To Be Tested  |  |  |  |  |  |  |
|         |               |  |  |  |  |  |  |
|         |               |  |  |  |  |  |  |

# **HPUCore implementation parameters**

The generic parameters used in SynthTactAER design are shown in Table  ${\bf 1}$ 

| Parameter name     | Display name                  | Description                                             | Def.  |
|--------------------|-------------------------------|---------------------------------------------------------|-------|
| C_RX_HAS_PAER      | PAER RX Interface             | If true (checked) the RX PAER interface is exposed      | True  |
| C_TX_HAS_PAER      | PAER TX Interface             | If true (checked) the TX PAER interface is exposed      | True  |
| C_PAER_DSIZE       | PAER Data Width               | Size of PAER address                                    | 24    |
| C_RX_HAS_HSSAER    | HSSAER RX Interface           | If true (checked) the RX HSSAER interface is exposed    | True  |
| C_RX_HSSAER_N_CHAN | HSSAER RX Channels            | The number of RX HSSAER channels [1-4]                  | 3     |
| C_TX_HAS_HSSAER    | HSSAER TX Interface           | If true (checked) the TX HSSAER interface is exposed    | True  |
| C_TX_HSSAER_N_CHAN | HSSAER TX Channels            | The number of TX HSSAER channels [1-4]                  | 3     |
| C_RX_HAS_GTP       | GTP RX Interface              | If true (checked) the RX GTP interface is exposed       | False |
| C_TX_HAS_GTP       | GTP TX Interface              | If true (checked) the TX GTP interface is exposed       | False |
| C_RX_HAS_SPNNLNK   | SpiNNlink RX Interface        | If true (checked) the RX SpiNNlink interface is exposed | True  |
| C_TX_HAS_ SPNNLNK  | SpiNNlink TX Interface        | If true (checked) the TX SpiNNlink interface is exposed | True  |
| C_PSPNNLNK_WIDTH   | SpiNNaker Parallel Data Width | Size of SpiNNaker parallel data interface               | 32    |
| C_DEBUG            | Debug Ports                   | If true (checked) the debug ports are exposed           | False |
| C_S_AXI_ADDR_WIDTH | AXI4 Lite Slave Address width | Size of AXI4 Lite Address bus                           | 8     |
| C_S_AXI_DATA_WIDTH | AXI4 Lite Slave Data width    | Size of AXI4 Lite Data bus                              | 32    |

Table 1 HPUCore implementation parameters in SynthTactAER design



## **Introduction**

The Head Processor Unit Core (HPU Core) is an AXI peripheral used to manage different input AER or SpiNNlink streaming and transfer the acquired data into memory through DMA interface or by reading registers with Host CPU. It is also Transmission capable, and permits to send AER or SpiNNlink streaming to external devices.

It has an Axi4 lite bus I/f for writing/reading internal registers and delivers two AXI stream bus @ 32bit (Read and Write lanes). It can be configured with up to 4 input channels and 1 output channel, and each channel can manage PAER, SAER, GTP (TBT), SpiNNlink flows.



Figure 1 HPUCore block

a list of the ports and their description is shown in Table 2.

| Comment             | Port name     | Width | Dir | Description                                                        |
|---------------------|---------------|-------|-----|--------------------------------------------------------------------|
| Interrupt           | Interrupt     | 1     | 0   | Level interrupt active high signal                                 |
|                     | S_AXI_ACLK    | 1     | I   | AXI Clock, System clock line IT MUST BE THE SAME AS HSSAER_ClkLS_p |
|                     | S_AXI_ARESETN | 1     | I   | AXI Reset active low line                                          |
|                     | S_AXI_AWADDR  | 32    | I   | AXI Write address                                                  |
|                     | S_AXI_AWVALID | 1     | I   | Write address valid                                                |
|                     | S_AXI_WDATA   | 32    | I   | Write data                                                         |
|                     | S_AXI_WSTRB   | 4     | I   | Write strobes                                                      |
| S                   | S_AXI_WVALID  | 1     | I   | Write valid                                                        |
| AXI4 Lite Bus lines | S_AXI_BREADY  | 1     | I   | Response ready                                                     |
| Bus                 | S_AXI_ARADDR  | 32    | I   | Read address                                                       |
| iţe                 | S_AXI_ARVALID | 1     | I   | Read address valid                                                 |
| (14 1               | S_AXI_RREADY  | 1     | I   | Read ready                                                         |
| ₹                   | S_AXI_ARREADY | 1     | 0   | Read address ready                                                 |
|                     | S_AXI_RDATA   | 32    | 0   | Read data                                                          |
|                     | S_AXI_RRESP   | 2     | 0   | Read response                                                      |
|                     | S_AXI_RVALID  | 1     | 0   | Read valid                                                         |
|                     | S_AXI_WREADY  | 1     | 0   | Write ready                                                        |
|                     | S_AXI_BRESP   | 2     | 0   | Write response                                                     |
|                     | S_AXI_BVALID  | 1     | 0   | Write response valid                                               |
|                     | S_AXI_AWREADY | 1     | 0   | Write address ready                                                |



| Comment          | Port name                         | Width | Dir | Description                                                 |
|------------------|-----------------------------------|-------|-----|-------------------------------------------------------------|
|                  | LRx_PAER_Addr                     | 18    | I   | Parallel AER address                                        |
|                  | LRx_PAER_Req                      | 1     | I   | Parallel AER request                                        |
| RX Left          | LRx_PAER_Ack                      | 1     | 0   | Parallel AER acknowledge                                    |
| Eye I/F          | LRx_HSSAER                        | 4     | I   | 4 channels High Speed Serial AER signal                     |
|                  | LRx_data_2of7_from_spinnaker      | 7     | I   | SpiNNlink input data line                                   |
|                  | LRx_ack_to_spinnaker_o            | 1     | 0   | SpiNNlink acknowledge                                       |
|                  | RRx_PAER_Addr                     | 18    | I   | Parallel AER address                                        |
|                  | RRx_PAER_Req                      | 1     | I   | Parallel AER request                                        |
| RX Right         | RRx_PAER_Ack                      | 1     | 0   | Parallel AER acknowledge                                    |
| Eye<br>I/F       | RRx_HSSAER                        | 4     | I   | 4 channels High Speed Serial AER signal                     |
| ,                | RRx_data_2of7_from_spinnaker      | 7     | I   | SpiNNlink input data line                                   |
|                  | RRx_ack_to_spinnaker_o            | 1     | 0   | SpiNNlink acknowledge                                       |
|                  | AuxRx_PAER_Addr                   | 18    | I   | Parallel AER address                                        |
|                  | AuxRx_PAER_Req                    | 1     | I   | Parallel AER request                                        |
| RX               | AuxRx_PAER_Ack                    | 1     | 0   | Parallel AER acknowledge                                    |
| Auxiliary<br>I/F | AuxRx_HSSAER                      | 4     | I   | 4 channels High Speed Serial AER signal                     |
| ,                | AuxRx_data_2of7_from_spinnaker    | 7     | I   | SpiNNlink input data line                                   |
|                  | AuxRx_ack_to_spinnaker_o          | 1     | 0   | SpiNNlink acknowledge                                       |
|                  | S_AXIS_TREADY                     | 1     | 0   | Tready                                                      |
| Slave Axi        | S_AXIS_TDATA                      | 32    | I   | Data bus                                                    |
| stream I/f       | S_AXIS_TLAST                      | 1     | I   | Last signal                                                 |
|                  | S_AXIS_TVALID                     | 1     | I   | Valid signal                                                |
|                  | M_AXIS_TREADY                     | 1     | I   | Tready                                                      |
| Master Axi       | M_AXIS_TDATA                      | 32    | 0   | Data bus                                                    |
| stream I/f       | M_AXIS_TLAST                      | 1     | 0   | Last signal                                                 |
|                  | M_AXIS_TVALID                     | 1     | 0   | Valid signal                                                |
|                  | Tx_PAER_Addr                      | 18    | 0   | Parallel AER address                                        |
| TX               | AuxRx_PAER_Req                    | 1     | 0   | Parallel AER request                                        |
| I/F              | AuxRx_PAER_Ack                    | 1     | I   | Parallel AER acknowledge                                    |
|                  | AuxRx_HSSAER                      | 3     | 0   | 3 channels High Speed Serial AER signal                     |
|                  | HSSAER_CIKLS_p, HSSAER_CIKLS_n    | 2     | I   | Differential 100MHz clock  IT MUST BE THE SAME AS S_AXI_CLK |
| System           | HSSAER_CIKHS_p,<br>HSSAER_CIKHS_n | 2     | I   | Differential 300MHz clock                                   |
| signals          | nSyncReset                        | 1     | I   | Active low Synchronous reset                                |
|                  | DefLocFarLpbk                     | 1     | I   | Default Far loopback value                                  |
|                  | DefLocNearLpbk                    | 1     | I   | Default Near loopback value                                 |

Table 2 HPUCore interface signals description



# 1 **HPUCore Block Diagram**

The HPUCore Block diagram is shown in Figure 2.



Figure 2 HPUCore architecture



### 1.1 Understanding the HPU Core in SynthTactAER Application

The HPU Core can have until 3 different AER generator connected to him. In the HPU Core implementation for SynthTactAER design the AER sources are configured as Serial AER lines. The Serial AER lines are LVDS signals and each source has 3 different channels. The 3 interfaces are:

- Left ATIS camera,
- Right ATIS camera and
- AUXiliary interface.

The HPU Core descrializes the data coming from its channels and fill a FIFO with data and associated time stamp.



Figure 3 Simplified block diagram of the HPUCore.

#### Table 3 Meaning of Timestamp and Data values.

#### TIMESTAMP (31 downto 0) when CTRLReg.15 is '0'

| TIME ID (Reserved) 31 downto 24 | Payload<br>23 downto 0 |
|---------------------------------|------------------------|
| 10000000                        | Time value             |

#### TIMESTAMP (31 downto 0) when CTRLReg.15 is '1'

| Payload<br>31 downto 0 |
|------------------------|
| Time value             |

Note: One-unit difference into Time value means 80ns.

Acording to the AERsensorsMap.xlsx (svn version r12867) the data are packed as in the tables that follow:

#### DATA (31 downto 0) coming from Left/Right eyes channels

| 31 | 30 29 28 27 | 26 | 25 | 24 | Payload<br>23 downto 0 |
|----|-------------|----|----|----|------------------------|
| 0  | 0 Reserved  |    | 0  | 0  | Data                   |



#### DATA (31 downto 0) coming from Aux channel

| 31 | 30 29 28 27 2 | 26 25 24            | Payload<br>23 downto 0 |
|----|---------------|---------------------|------------------------|
| 0  | Reserved      | Copy of data[21:19] | Data                   |

The AXI stream I/f is connected to a DMA used to perform slave to memory transfers.

Reading from /dev/iit-hpu we obtain couples of 32bit wide data. The first data is a timestamp while the second one is the data associated to the timestamp.

The Table 3 shows the meaning of both timestamp and data values.

Then a typical acquired sequence is as in the table below:

| Example of acquired sequence   | Events Notes:                                                                                        |
|--------------------------------|------------------------------------------------------------------------------------------------------|
| Example of dequired sequence   | All events in the table come from Left Eye through SAER interface                                    |
| T: 0x80FFFD1D> TD: 0x040132E5  | The payload for TD event is 0x132E5                                                                  |
| T: 0x80FFFD9E> TD: 0x040132E6  | The payload for TD event is 0x132E6                                                                  |
| T: 0x80FFFE1F> TD: 0x040132E7  | The payload for TD event is 0x132E7                                                                  |
| T: 0x80FFFEA0> TD: 0x040132E8  | The payload for TD event is 0x132E8                                                                  |
| T: 0x80FFFEB8> APS: 0x0405C600 | This is a APS event because of the $18^{\rm th}$ bit is high. The payload for APS event is $0x1C600$ |
| T: 0x80FFFF21> TD: 0x040132E9  | The payload for TD event is 0x132E9                                                                  |
| T: 0x80FFFFA2> TD: 0x040132EA  | The payload for TD event is 0x132EA                                                                  |
| T: 0x80000023> TD: 0x040132EB  | Here the time stamp has wrapped incrementing the wrap value. The payload for TD event is 0x132EB     |



## 2 HPUCore internal registers

In this Section a detailed view of the registers internal to the HPUCore module is given.

The HPUCore block has an Axi Light Slave interface [1] to interface the registers with the hosting processor.

AXI is part of ARM AMBA, a family of micro controller buses first introduced in 1996. The first version of AXI was first included in AMBA 3.0, released in 2003. AMBA 4.0, released in 2010, includes the second version of AXI, AXI4. There are three types of AXI4 interfaces:

- AXI4—for high-performance memory-mapped requirements.
- AXI4-Lite—for simple, low-throughput memory-mapped communication (for example, to and from control and status registers).
- AXI4-Stream—for high-speed streaming data.

Xilinx introduced these interfaces in the ISE® Design Suite, release 12.3.

In the following the complete list of accessible HPUCore registers.

| #  | Offset | Mnemonic                  | Description                            | Туре | Reset<br>Value |
|----|--------|---------------------------|----------------------------------------|------|----------------|
| 0  | 0x00   | CTRL REG                  | Control register                       | R/W  | 0x00000000     |
| 1  | 0x04   | LPBK_LR_CNFG_REG          | Loopback LR Configuration register     | R/W  | 0x00000000     |
| 2  | 0x08   | RXData REG                | RX Data Buffer                         | R/O  | 0x00000000     |
| 3  | 0x0C   | RXTime REG                | RX Time Buffer                         | R/O  | 0x00000000     |
| 4  | 0x10   | TXData REG                | TX Data Buffer                         | R/W  | 0x00000000     |
| 5  | 0x14   | DMA_BREG                  | DMA Burst Register                     | R/W  | 0x00000000     |
| 6  | 0x18   | STAT RAW REG              | Status RAW register                    | R/O  | 0x00000000     |
| 7  | 0x1C   | IRQ REG                   | IRQ register                           | R/C  | 0x00000000     |
| 8  | 0x20   | MSK REG                   | Mask register for the IRQ_REG register | R/W  | 0x00000000     |
| 10 | 0x28   | WRAPTimeStamp_REG         | Wrapping TimeStamp Register            | R/C  | 0x00000000     |
| 13 | 0x34   | HSSAER_STAT               | HSSAER status register                 | R/O  | 0x00000000     |
| 14 | 0x38   | HSSAER RX ERR             | HSSAER RX Error register               | R/O  | 0x00000000     |
| 15 | 0x3C   | HSSAER RX MSK             | HSSAER RX Mask register                | R/W  | 0x00000000     |
| 16 | 0x40   | RX CTRL REG               | RX Control register                    | R/W  | 0x00000000     |
| 17 | 0x44   | TX CTRL REG               | TX Control register                    | R/W  | 0x00000000     |
| 18 | 0x48   | RX PAER CNFG REG          | RX PAER configuration register         | R/W  | 0x01010100     |
| 19 | 0x4C   | TX_PAER_CFNG_REG          | TX PAER Configuration register         | R/W  | 0x00000000     |
| 20 | 0x50   | IP CFNG REG               | IP implemented configuration register  | R/O  | 0x0000????     |
| 21 | 0x54   | FIFO_THRS_REG             | FIFO threshold value register          | R/W  | 0x00000000     |
| 22 | 0x58   | LPBK AUX CNFG REG         | Loopback AUX Configuration register    | R/W  | 0x00000000     |
| 23 | 0x5C   | ID_REG                    | ID Register                            | R/O  | 0x48505520     |
| 24 | 0x60   | AUX CTRL REG              | Auxiliary interface Control register   | R/W  | 0x00000000     |
| 25 | 0x64   | HSSAER AUX RX ERR         | HSSAER AUX RX Error register           | R/O  | 0x00000000     |
| 26 | 0x68   | HSSAER AUX RX MSK         | HSSAER AUX RX Mask register            | R/W  | 0x00000000     |
| 27 | 06C    | HSSAER AUX RX ERR THR REG | HSSAER AUX RX error threshold          | R/W  | 0x10101010     |



| #  | Offset | Mnemonic                  | Description                                        | Туре | Reset<br>Value |
|----|--------|---------------------------|----------------------------------------------------|------|----------------|
|    |        |                           | register                                           |      |                |
| 28 | 0x70   | HSSAER AUX RX ERR CHO REG | HSSAER AUX RX error counter register for Channel 0 | R/C  | 0x00000000     |
| 29 | 0x74   | HSSAER AUX RX ERR CH1 REG | HSSAER AUX RX error counter register for Channel 1 | R/C  | 0x00000000     |
| 30 | 0x78   | HSSAER AUX RX ERR CH2 REG | HSSAER AUX RX error counter register for Channel 2 | R/C  | 0x00000000     |
| 31 | 0x7C   | HSSAER AUX RX ERR CH3 REG | HSSAER AUX RX error counter register for Channel 3 | R/C  | 0x00000000     |
| 32 | 0x80   | SPNN START KEY REG        | SpiNNlink Start command key                        | R/W  | 0x80000000     |
| 33 | 0x84   | SPNN STOP KEY REG         | SpiNNlink Stop command key                         | R/W  | 0x40000000     |
| 34 | 0x88   | SPNN TX MASK REG          | SpiNNlink TX Data Mask                             | R/W  | 0x00FFFFF      |
| 35 | 0x8C   | SPNN_RX_MASK_REG          | SpiNNlink RX Data Mask                             | R/W  | 0x00FFFFF      |
| 36 | 0x90   | SPNN CTRL REG             | SpiNNaker Control Register                         | R/W  | 0x00000000     |
| 37 | 0x94   | SPNN STATUS REG           | SpiNNaker Status Register                          | R/O  | 0x00000000     |
| 38 | 0xA0   | TlastTimeOut_REG          | TLAST Time Out register                            | R/W  | 0x00010000     |
| 39 | 0xA4   | <u>TlastConter_REG</u>    | TLAST Counter register                             | R/O  | 0x00000000     |
| 40 | 0xA8   | TdataCounter REG          | TData Counter register                             | R/O  | 0x00000000     |
| 41 | 0xAC   | Reserved                  |                                                    |      |                |



### 2.1 Control register (CTRL\_REG)

This register is used to control the behaviour of the HPUCore block.

| CTRL_                     | _REG (I                     | HPUCor                  | e Base                  | + 0x00                        | <b>)</b> )                    |                                  |                     |                                   |                                   |                          |                     | Rese         | t Value:  | 0x000     | 00000          |
|---------------------------|-----------------------------|-------------------------|-------------------------|-------------------------------|-------------------------------|----------------------------------|---------------------|-----------------------------------|-----------------------------------|--------------------------|---------------------|--------------|-----------|-----------|----------------|
| 31                        | 30                          | 29                      | 28                      | 27                            | 26                            | 25                               | 24                  | 23                                | 22                                | 21                       | 20                  | 19           | 18        | 17        | 16             |
| LocFar<br>RPAER<br>Lpbk   | LocFar<br>PAERL<br>pbk      | LocFar<br>RSAER<br>Lpbk | LocFar<br>LSAER<br>Lpbk | LocFar<br>AuxPA<br>ERLpb<br>k | LocFar<br>AuxSA<br>ERLpb<br>k | Loc<br>Near<br>Lpbk              | Remot<br>e Lpbk     | LocFar<br>SpinnL<br>pbkSel<br>(1) | LocFar<br>SpinnL<br>pbkSel<br>(0) |                          |                     | Rese         | erved     |           |                |
| r/w                       | r/w r/w r/w r/w r/w r/w r/w |                         |                         |                               |                               |                                  |                     |                                   |                                   |                          |                     |              |           |           |                |
| 15                        | 14                          | 13                      | 12                      | 11                            | 10                            | 9                                | 8                   | 7                                 | 6                                 | 5                        | 4                   | 3            | 2         | 1         | 0              |
| Full<br>Time<br>stam<br>p |                             | I                       | Reserve                 | d                             |                               | AXIS<br>trea<br>m<br>Late<br>ncy | Flush<br>TX<br>FIFO | AuxRxPa<br>er FIFO<br>FLush       | RRxPaer<br>FIFO<br>FLush          | LRxPaer<br>FIFO<br>FLush | Flush<br>RX<br>FIFO | Rese<br>rved | EN<br>INT | EN<br>DMA | DMA<br>running |
| r/w                       | <u> </u>                    | <u> </u>                | <u> </u>                |                               | <u> </u>                      | <u> </u>                         | s/c                 | s/c                               | s/c                               | s/c                      | s/c                 | <u> </u>     | r/w       | r/w       | ro             |

- Local Far PAER/SAER Loopback enabling (for further details, look at the RTL code)
- Local Near Loopback enabling (for further details, look at the RTL code)
- Remote Loopback enabling (for further details, look at the RTL code)
- Local Far SpinnLink Loopback selection (for further details, look at the RTL code):
  - When '00' No Loopback
  - When '01' Tx is sent to "LEFT" Rx
  - When '10' Tx is sent to "RIGHT" Rx
  - o When '11' Tx is sent to "AUX" Rx
- DMA running
  - When '1' it shows that the DMA transfer is on going
  - When '0' it shows that no DMA transfer is active
- EN DMA is the DMA interface Enable
  - When '1' the DMA I/f is enabled
  - When '0' the DMA I/f is disabled
- Enable Interrupt
  - When '1' the Interrupt is enabled
  - When '0' the Interrupt never rises up
- FlushRXFIFO
  - When set to '1' the RX FIFO of the HPUCore is flushed. This bit is automatically cleared.
- LRxPAER Flush FIFOS
  - When set to '1' the FIFOS of the Left PAER interface are flushed. This bit is automatically cleared.
- RRxPAER Flush FIFOS
  - $_{\odot}$   $\,$  When set to '1' the FIFOS of the Right PAER interface are flushed. This bit is automatically cleared.
- AuxRxPAER Flush FIFOS
  - $\circ$  When set to '1' the FIFOS of the AUX PAER interface are flushed. This bit is automatically cleared.
- FlushTXFIFO
  - o When set to `1' the TX FIFO of the HPUCore is flushed. This bit is automatically cleared.
- AXIStream Latency
  - When set to 1 the HPU based on the TLAST TIMEOUT Register (TLASTTO\_REG) can have a maximum latency equal to the value of the register multiplied by the period of the system clock
- Fulltimestamp
  - When set to '1' the Timestamp is 32 bit wide, when set to '0' the time stamp is 24 bit wide and the higher part is equal to 0x80.



## 2.2 Loopback LR Configuration register (LPBK\_LR\_CNFG\_REG)

This register contains the configuration for Left and Right loopback.

| LPBK_ | _LR_CN   | IFG_RE  | G (HPU | Core B | ase + 0   | x04)    |      |      |          |         |      | Rese  | t Value: | 0x000    | 00000 |
|-------|----------|---------|--------|--------|-----------|---------|------|------|----------|---------|------|-------|----------|----------|-------|
| 31    | 30       | 29      | 28     | 27     | 26        | 25      | 24   | 23   | 22       | 21      | 20   | 19    | 18       | 17       | 16    |
| Righ  | t RX cha | n 3 LPB | cnfg   | Righ   | t RX cha  | n 2 LPB | cnfg | Righ | t RX cha | n 1 LPB | cnfg | Right | t RX cha | ın 0 LPB | cnfg  |
|       | r/w r/w  |         |        |        |           |         |      |      | r/       | W       |      |       | r/       | 'W       |       |
|       |          |         |        |        |           |         |      |      |          |         |      |       |          |          |       |
| 15    | 14       | 13      | 12     | 11     | 10        | 9       | 8    | 7    | 6        | 5       | 4    | 3     | 2        | 1        | 0     |
| Left  | RX char  | 1 3 LPB | cnfg   | Left   | : RX chai | n 2 LPB | cnfg | Left | RX char  | 1 LPB   | cnfg | Left  | RX cha   | n 0 LPB  | cnfg  |
|       | r/       | w       |        | ı      | r/        | w       |      | I    | r/       | W       |      | ı     | r/       | 'w       |       |

The register is used in debug to test the connection. For further details, look at the RTL code.



### 2.3 RX Data Buffer register (RXDATA\_REG)

This register contains the data (read from the INFIFO) coming from the selected by N\_MuxAddr NMC. The format of the register is depicted into the figure below.

| RXDA | TA_RE | G (HPU | Core Ba | se + 0 | x08) |         |    |     |    |    |    | Reset | t Value: | 0x0000 | 00000    |
|------|-------|--------|---------|--------|------|---------|----|-----|----|----|----|-------|----------|--------|----------|
| 31   | 30    | 29     | 28      | 27     | 26   | 25      | 24 | 23  | 22 | 21 | 20 | 19    | 18       | 17     | 16       |
|      |       |        |         |        | F    | Reserve | t  |     |    |    |    |       |          | Data   |          |
|      |       |        |         |        |      |         |    |     |    |    |    |       |          | r/o    | <u>.</u> |
|      |       |        |         |        |      |         |    |     |    |    |    |       |          |        |          |
| 15   | 14    | 13     | 12      | 11     | 10   | 9       | 8  | 7   | 6  | 5  | 4  | 3     | 2        | 1      | 0        |
|      |       |        |         |        |      |         | Da | ata |    |    |    |       |          |        |          |
|      |       |        |         |        |      |         | r  | /n  |    |    |    |       |          |        |          |

The meaning of this register is as explained in Table 3.

NOTE: The reading of this register must follow the reading of the RX Time Buffer register (RXTIME\_REG).



### 2.4 RX Time Buffer register (RXTIME\_REG)

This register contains the time stamp associated to the received data (see Loopback LR Configuration register (LPBK\_LR\_CNFG\_REG)

This register contains the configuration for Left and Right loopback.

| LPBK_ | _LR_CN   | IFG_RE  | G (HPU | Core B | ase + 0  | x04)    |      |      |         |         |      | Rese  | t Value: | 0x000   | 00000    |
|-------|----------|---------|--------|--------|----------|---------|------|------|---------|---------|------|-------|----------|---------|----------|
| 31    | 30       | 29      | 28     | 27     | 26       | 25      | 24   | 23   | 22      | 21      | 20   | 19    | 18       | 17      | 16       |
| Right | t RX cha | n 3 LPB | cnfg   | Righ   | t RX cha | n 2 LPB | cnfg | Righ | RX cha  | n 1 LPB | cnfg | Right | t RX cha | n 0 LPB | cnfg     |
|       | r/       | W       |        |        | r/       | W       |      |      | r/      | W       |      |       | r/       | W       |          |
|       |          |         |        |        |          |         |      |      |         |         |      |       |          |         |          |
| 15    | 14       | 13      | 12     | 11     | 10       | 9       | 8    | 7    | 6       | 5       | 4    | 3     | 2        | 1       | 0        |
| Left  | RX char  | 1 3 LPB | cnfg   | Left   | RX char  | n 2 LPB | cnfg | Left | RX char | n 1 LPB | cnfg | Left  | RX char  | n 0 LPB | cnfg     |
|       | r/       | W       |        | •      | r/       | W       |      |      | r/      | W       |      |       | r/       | W       | <u>'</u> |

The register is used in debug to test the connection. For further details, look at the RTL code.



RX Data Buffer register (RXDATA\_REG)) from the INFIFO.

| RXTIN | 1E_REG | G (HPUC | Core Ba | se + 0 | (0C) |    |      |       |    |    |      | Rese  | t Value: | 0x000 | 00000 |
|-------|--------|---------|---------|--------|------|----|------|-------|----|----|------|-------|----------|-------|-------|
| 31    | 30     | 29      | 28      | 27     | 26   | 25 | 24   | 23    | 22 | 21 | 20   | 19    | 18       | 17    | 16    |
|       |        |         | 1000    | 0000   |      |    |      |       |    |    | Time | stamp |          |       |       |
|       |        |         |         |        |      |    | r    | 0     |    |    |      |       |          |       |       |
|       |        |         |         |        |      |    |      |       |    |    |      |       |          |       |       |
| 15    | 14     | 13      | 12      | 11     | 10   | 9  | 8    | 7     | 6  | 5  | 4    | 3     | 2        | 1     | 0     |
|       |        |         |         |        |      |    | Time | stamp |    |    |      |       |          |       |       |

ro

The Time Stamp value read from this register is the Time Stamp that the HPUCore sticks to the Received data available into the RX Data Buffer register (RXDATA\_REG).



### 2.5 TX Data Buffer register (TXDATA REG)

This register is used to fill the OUTFIFO.

| TXDA | TA_REG | G (HPU | Core Ba | se + 0 | (10) |    |     |      |    |    |    | Rese | t Value: | 0x000 | 00000 |
|------|--------|--------|---------|--------|------|----|-----|------|----|----|----|------|----------|-------|-------|
| 31   | 30     | 29     | 28      | 27     | 26   | 25 | 24  | 23   | 22 | 21 | 20 | 19   | 18       | 17    | 16    |
|      |        |        |         |        |      |    | TXE | Data |    |    |    |      |          |       |       |
|      |        |        |         |        |      |    | r   | W    |    |    |    |      |          |       |       |
|      |        |        |         |        |      |    |     |      |    |    |    |      |          |       |       |
| 15   | 14     | 13     | 12      | 11     | 10   | 9  | 8   | 7    | 6  | 5  | 4  | 3    | 2        | 1     | 0     |
|      |        |        |         |        |      |    | TXE | Data |    |    |    |      |          |       |       |
|      |        |        |         |        |      |    |     |      |    |    |    |      |          |       |       |

rw

When writing to this register, keep in mind that it is used by the internal hw as follows:

The register needs to be written twice to enable the correct behaviour.

The first data written into the register represents the time, elapsed which, the second data written into the register is delivered to the *loopback* module, routing it according to its MSB bit:

00 = > the packet is sent to the parallel AER interface 01 = > the packet is sent to the HSSAER interface

10 => the packet is sent to the SpiNNlink interface ----- it was: GTP driver interface

11 => the packet is sent to all the interfaces: it is acknowledged only when all the interfaces have acknowledged the transfer



### 2.6 DMA register (DMA REG)

This register is used set the behaviour of the Axistream interface. It represents the number of data (32 bit size length) sent to the DMA interface and "closed" by a TLAST on the axistream interface.

Please note that this value has bit 0 set to 0, this means that it cannot be written with an odd value.

NOTE: This register can be written only if CTRL\_REG.ENDMA='0'.

| DMA_ | REG (H | <b>IPUCore</b> | e Base | + 0x14 | )  |     |          |       |    |    |    | Rese | t Value: | 0x000 | 00100                    |
|------|--------|----------------|--------|--------|----|-----|----------|-------|----|----|----|------|----------|-------|--------------------------|
| 31   | 30     | 29             | 28     | 27     | 26 | 25  | 24       | 23    | 22 | 21 | 20 | 19   | 18       | 17    | 16                       |
|      |        |                |        |        |    | I   | reserved | i     |    |    |    |      |          |       | DMA<br>_test<br>mod<br>e |
|      |        |                |        |        |    |     |          |       |    |    |    |      |          |       | r/w                      |
|      |        |                |        |        |    |     |          | _     | _  | _  |    | _    |          |       |                          |
| 15   | 14     | 13             | 12     | 11     | 10 | 9   | 8        | 7     | 6  | 5  | 4  | 3    | 2        | 1     | 0                        |
|      |        |                |        |        |    | DMA | Length[  | 15:1] |    |    |    |      |          |       | 0                        |
|      |        |                |        |        |    |     | r/       | w     |    |    |    |      |          |       | •                        |

r/w

The DM\_test\_mode set to '1' enables the DMA to write consecutive incremental values at high rates.

For example, if it is set to 8, the burst from/to the DMA I/f will be in terms of 8 data length.





### 2.7 RAW Status Register (STAT\_RAW\_REG)

When read, this register gives a snapshot of the status of warning or errors signals. It is a Read Only register.

| STAT_            | _RAW_                             | REG (H                      | PUCore                      | Base - | + 0x18)                   | )                              |                       |                                  |                             |                             |                                  | Rese                     | t Value:                 | 0x000                                 | 00000                    |
|------------------|-----------------------------------|-----------------------------|-----------------------------|--------|---------------------------|--------------------------------|-----------------------|----------------------------------|-----------------------------|-----------------------------|----------------------------------|--------------------------|--------------------------|---------------------------------------|--------------------------|
| 31               | 30                                | 29                          | 28                          | 27     | 26                        | 25                             | 24                    | 23                               | 22                          | 21                          | 20                               | 19                       | 18                       | 17                                    | 16                       |
|                  | I                                 | Reserved                    | d                           |        | AuxS<br>pinn<br>RxEr<br>r | RSpi<br>nnRx<br>Err            | LSpi<br>nnRx<br>Err   | AuxS<br>pinn<br>Parit<br>yErr    | RSpi<br>nnPa<br>rityE<br>rr | LSpi<br>nnPa<br>rityE<br>rr | TxSp<br>innD<br>ump              | Glbl<br>RX<br>err_<br>of | Glbl<br>RX<br>err_t<br>o | Glbl<br>RX<br>err_t<br>x              | Glbl<br>RX<br>err_k<br>o |
|                  |                                   |                             |                             |        | ro                        | ro                             | ro                    | ro                               | ro                          | ro                          | ro                               | ro                       | ro                       | ro                                    | ro                       |
| 15               | 14                                | 13                          | 12                          | 11     | 10                        | 9                              | 8                     | 7                                | 6                           | 5                           | 4                                | 3                        | 2                        | 1                                     | 0                        |
| RXFIFO<br>> THRS | AUX<br>RX<br>PAER<br>FIFO<br>FULL | RRX<br>PAER<br>FIFO<br>FULL | LRX<br>PAER<br>FIFO<br>FULL | Rese   | erved                     | RX<br>FIFO<br>Not<br>Empt<br>y | RxBu<br>fferR<br>eady | Time<br>Stam<br>p<br>Wra<br>pped | Rese<br>rved                | TX<br>Data<br>Full          | TX<br>Data<br>Almo<br>st<br>Full | TX<br>Data<br>Empt<br>y  | RX<br>Data<br>Full       | RX<br>Data<br>Almo<br>st<br>Empt<br>y | RX<br>Data<br>Empt<br>y  |
|                  | ro                                | ro                          | ro                          |        |                           | ro                             | ro                    | ro                               |                             | ro                          | ro                               | ro                       | ro                       | ro                                    | ro                       |

- RxDataEmpty
  - When '0', the INFIFO is not empty
  - When '1' the INFIFO is empty
- RxDataAlmostEmpty
  - When '1' the INFIFO has 1 or 0 data to be read.
  - When '0' the INFIFO has more or equal two data to be read.
- RxDataFull
  - When '1' the INFIFO is full.
  - When '0' the INFIFO is not full.
- TxDataEmpty
  - When '0', the OUTFIFO is not empty
  - When '1' the OUTFIFO is empty
- TxDataAlmostFull
  - When '1' the OUTFIFO has 2047 or 2048 data within himself.
  - When '0' the OUTFIFO has less than 2047 data within himself.
- TxDataFull
  - o When '1' the OUTFIFO is full.
  - When '0' the OUTFIFO is not full.
- Bias Finished
  - When '1' the Bias signals have been latched
  - When '0' no Bias signals have been latched
- Time stamp wrapped (this bit is high for one clock period only, when the counter wraps its value)
  - When '1' the counter inside the TimeStamp module has wrapped its value.
  - When '0' the counter inside the TimeStamp module has not yet wrapped its value
- RXBufferReady
  - When '1' the Rx Fifo has at least DMA\_REG value of data available
  - When '0' the Rx Fifo has less than DMA\_REG value of data available
- RXFifoNotEmpty
  - When '1' the RX Fifo is not empty.
  - When '0' the RX Fifo is empty
- LRXPaerFifoFull
  - When '1' the Left RX Fifo is not empty.
  - When '0' the Left RX Fifo is empty
- RRXPaerFifoFull



- When '1' the Right RX Fifo is not empty.
- When '0' the Right RX Fifo is empty

#### AuxRXPaerFifoFull

- When '1' the Aux RX Fifo is not empty.
- When '0' the Aux RX Fifo is empty

#### RXfifo>Threshold

- When '1' the Infifo has more elements with respect the value written into Fifo Threshold register (FIFO\_THRSH\_REG).
- When '0' the Infifo has lesse elements with respect the value written into Fifo Threshold register (FIFO\_THRSH\_REG.

#### · Glbl Rx err ko

Global Rx err ko. (see [3] for further details)

It's an logic *or* between any unmasked errors detected on Left eye, Right eye and the number of errors in Aux interface overcoming the Aux Error counter threshold register (HSSAER\_AUX\_RX\_ERR\_THR\_REG).

#### • Glbl Rx err rx

o Global Rx err rx. (see [3] for further details)

It's an logic *or* between any unmasked errors detected on Left eye, Right eye and the number of errors in Aux interface overcoming the Aux Error counter threshold register (HSSAER\_AUX\_RX\_ERR\_THR\_REG).

#### · Glbl Rx err to

Global Rx err to. (see [3] for further details)

It's an logic *or* between any unmasked errors detected on Left eye, Right eye and the number of errors in Aux interface overcoming the Aux Error counter threshold register (HSSAER\_AUX\_RX\_ERR\_THR\_REG).

#### Glbl Rx err of

Global Rx err of. (see [3] for further details)

It's an logic *or* between any unmasked errors detected on Left eye, Right eye and the number of errors in Aux interface overcoming the Aux Error counter threshold register (HSSAER\_AUX\_RX\_ERR\_THR\_REG).



#### TxSpinnDump

- When '0', the SpiNNlink TX is working
- When '1', the SpiNNlink TX is "dumping" data

#### LSpinnRxErr

- When '0', the Left SpiNNlink RX is working
- When '1', the Left SpiNNlink RX is receiving wrong symbols

#### RSpinnRxErr

- When '0', the Right SpiNNlink RX is working
- When '1', the Right SpiNNlink RX is receiving wrong symbols

#### AuxSpinnRxErr

- When '0', the Aux SpiNNlink RX is working
- When '1', the Aux SpiNNlink RX is receiving wrong symbols

#### LSpinnParityErr

- When '0', the Left SpiNNlink RX is working
- When '1', the Left SpiNNlink RX is receiving packets with wrong parity



- RSpinnParityErr
  - o When '0', the Right SpiNNlink RX is working
  - o When '1', the Right SpiNNlink RX is receiving packets with wrong parity
- AuxSpinnParityErr

  - When '0', the Aux SpiNNlink RX is working
    When '1', the Aux SpiNNlink RX is receiving packets with wrong parity



## 2.8 IRQ Register (IRQ\_REG)

When read, this register gives the status of the collected warning or errors signals. It is a Read/Set register, i.e., to clear the warning/error bit the user has to write '1' on the corresponding bit position.



| IRQ_             | REG (H                            | PUCore                      | Base +                      | - 0x1C | )                         |                                |                       |                                  |                             |                             |                                  | Rese                     | t Value:                 | 0x0000                                | 00000                    |
|------------------|-----------------------------------|-----------------------------|-----------------------------|--------|---------------------------|--------------------------------|-----------------------|----------------------------------|-----------------------------|-----------------------------|----------------------------------|--------------------------|--------------------------|---------------------------------------|--------------------------|
| 31               | 30                                | 29                          | 28                          | 27     | 26                        | 25                             | 24                    | 23                               | 22                          | 21                          | 20                               | 19                       | 18                       | 17                                    | 16                       |
|                  |                                   | Reserve                     | d                           |        | AuxS<br>pinn<br>RxEr<br>r | RSpi<br>nnRx<br>Err            | LSpi<br>nnRx<br>Err   | AuxS<br>pinn<br>Parit<br>yErr    | RSpi<br>nnPa<br>rityE<br>rr | LSpi<br>nnPa<br>rityE<br>rr | TxSp<br>innD<br>ump              | Glbl<br>RX<br>err_<br>of | Glbl<br>RX<br>err_t<br>o | Glbl<br>RX<br>err_r<br>x              | Glbl<br>RX<br>err_k<br>o |
|                  |                                   |                             | r/c                         | r/c    | r/c                       | r/c                            | r/c                   | r/c                              | r/c                         | r/c                         | r/c                              | r/c                      | r/c                      | r/c                                   | r/c                      |
| 15               | 14                                | 13                          | 12                          | 11     | 10                        | 9                              | 8                     | 7                                | 6                           | 5                           | 4                                | 3                        | 2                        | 1                                     | 0                        |
| RXFIFO<br>> THRS | AUX<br>RX<br>PAER<br>FIFO<br>FULL | RRX<br>PAER<br>FIFO<br>FULL | LRX<br>PAER<br>FIFO<br>FULL | Rese   | erved                     | RX<br>FIFO<br>Not<br>Empt<br>y | RxBu<br>fferR<br>eady | Time<br>Stam<br>p<br>Wra<br>pped | Rese<br>rved                | TX<br>Data<br>Full          | TX<br>Data<br>Almo<br>st<br>Full | TX<br>Data<br>Empt<br>y  | RX<br>Data<br>Full       | RX<br>Data<br>Almo<br>st<br>Empt<br>y | RX<br>Data<br>Empt<br>Y  |
| r/c              | r/c                               | r/c                         | r/c                         |        |                           | r/c                            | r/c                   | r/c                              |                             | r/c                         | r/c                              | r/c                      | r/c                      | r/c                                   | r/c                      |

The meaning of the masked contributors of this register is the same of the RAW Status Register (STAT\_RAW\_REG).



### 2.9 Mask Register (MSK\_REG)

This is the Mask register used to mask the contributors for the interrupt signal.

| MSK_             | REG (H                            | PUCore                      | Base -                      | + 0x20 | )     |                                |                       |                                  |              |                    |                                  | Rese                     | t Value:                 | 0x0000                                | 00000                    |
|------------------|-----------------------------------|-----------------------------|-----------------------------|--------|-------|--------------------------------|-----------------------|----------------------------------|--------------|--------------------|----------------------------------|--------------------------|--------------------------|---------------------------------------|--------------------------|
| 31               | 30                                | 29                          | 28                          | 27     | 26    | 25                             | 24                    | 23                               | 22           | 21                 | 20                               | 19                       | 18                       | 17                                    | 16                       |
|                  |                                   |                             |                             |        | Rese  | erved                          |                       |                                  |              |                    |                                  | Glbl<br>RX<br>err_<br>of | Glbl<br>RX<br>err_t<br>o | Glbl<br>RX<br>err_t<br>x              | Glbl<br>RX<br>err_k<br>o |
|                  |                                   |                             |                             |        |       |                                |                       |                                  |              |                    |                                  | r/w                      | r/w                      | r/w                                   | r/w                      |
| 15               | 14                                | 13                          | 12                          | 11     | 10    | 9                              | 8                     | 7                                | 6            | 5                  | 4                                | 3                        | 2                        | 1                                     | 0                        |
| RXFIFO<br>> THRS | AUX<br>RX<br>PAER<br>FIFO<br>FULL | RRX<br>PAER<br>FIFO<br>FULL | LRX<br>PAER<br>FIFO<br>FULL | Rese   | erved | RX<br>FIFO<br>Not<br>Empt<br>y | RxBu<br>fferR<br>eady | Time<br>Stam<br>p<br>Wra<br>pped | Rese<br>rved | TX<br>Data<br>Full | TX<br>Data<br>Almo<br>st<br>Full | TX<br>Data<br>Empt<br>y  | RX<br>Data<br>Full       | RX<br>Data<br>Almo<br>st<br>Empt<br>y | RX<br>Data<br>Empt<br>y  |
| r/w              | r/w                               | r/w                         | r/w                         |        |       | r/w                            | r/w                   | r/w                              |              | r/w                | r/w                              | r/w                      | r/w                      | r/w                                   | r/w                      |

The meaning of the masked contributors of this register is the same of the RAW Status Register (STAT\_RAW\_REG).



### 2.10 Wrapping TimeStamp Register (WRAPTimeStamp\_REG)

This register is used to read how many times the internal 32bit counter of the TimeStamp module has wrapped its value. In case the user writes any value in this register, it will be cleared and also the internal 32bit counter of the TimeStamp module will be cleared.

| WRAP | TIMES | TAMP_ | REG (N | IEUELA | B Base | + 0x28 | 3)      |          |    |    |    | Rese | t Value: | 0x000 | 00000 |
|------|-------|-------|--------|--------|--------|--------|---------|----------|----|----|----|------|----------|-------|-------|
| 31   | 30    | 29    | 28     | 27     | 26     | 25     | 24      | 23       | 22 | 21 | 20 | 19   | 18       | 17    | 16    |
|      |       |       |        |        |        |        | Wrappir | ng times |    |    |    |      |          |       |       |
|      |       |       |        |        |        |        | r,      | ′c       |    |    |    |      |          |       |       |
|      |       |       |        |        |        |        |         |          |    |    |    |      |          |       |       |
| 15   | 14    | 13    | 12     | 11     | 10     | 9      | 8       | 7        | 6  | 5  | 4  | 3    | 2        | 1     | 0     |
|      | •     |       |        | •      | •      |        | Wrappir | ng times |    |    | •  | •    |          | •     |       |

r/c



### 2.11 HSSAER STATus register (HSSAER\_STAT\_REG)

This is the HSSAER Status register.

| HSSAI | ER_STA | T_REG | (HPUC | ore Bas              | se + 0x              | 34)                  |                      |    |      |       |    | Rese                 | t Value:             | 0x000                | 00000                |
|-------|--------|-------|-------|----------------------|----------------------|----------------------|----------------------|----|------|-------|----|----------------------|----------------------|----------------------|----------------------|
| 31    | 30     | 29    | 28    | 27                   | 26                   | 25                   | 24                   | 23 | 22   | 21    | 20 | 19                   | 18                   | 17                   | 16                   |
|       | Rese   | rved  |       | Chan3<br>Aux<br>run  | Chan2<br>Aux<br>run  | Chan1<br>Aux<br>run  | Chan0<br>Aux<br>run  |    | Rese | erved |    | Chan3<br>TX run      | Chan2<br>TX run      | Chan1<br>TX run      | Chan0<br>TX run      |
|       |        |       |       | ro                   | ro                   | ro                   | ro                   |    |      |       |    | ro                   | ro                   | ro                   | Ro                   |
| 15    | 14     | 13    | 12    | 11                   | 10                   | 9                    | 8                    | 7  | 6    | 5     | 4  | 3                    | 2                    | 1                    | 0                    |
|       | Rese   | rved  |       | Chan3<br>R RX<br>run | Chan2<br>R RX<br>run | Chan1<br>R RX<br>run | Chan0<br>R RX<br>run |    | Rese | erved |    | Chan3<br>L RX<br>run | Chan2<br>L RX<br>run | Chan1<br>L RX<br>run | Chan0<br>L RX<br>run |
|       |        |       |       | r٥                   | r٥                   | r٥                   | r٥                   |    |      |       |    | ro                   | r٥                   | rΩ                   | ro                   |

The user can read the status of the 4 channels of Left Rx Eye, Right Rx Eye, Aux Rx or Tx channel.



## 2.12 HSSAER RX Error register (HSSAER\_RX\_ERR\_REG)

This is the HSSAER Rx error register.

| HSSA                    | ER_RX_                  | _ERR_R                  | EG (HF                  | UCore                   | Base +                  | 0x38)                   |                         |                         |                         |                         |                         | Rese                    | t Value:                | 0x000                   | 00000                   |
|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|
| 31                      | 30                      | 29                      | 28                      | 27                      | 26                      | 25                      | 24                      | 23                      | 22                      | 21                      | 20                      | 19                      | 18                      | 17                      | 16                      |
| Chan3<br>R RX<br>err_of | Chan3<br>R RX<br>err_to | Chan3<br>R RX<br>err_rx | Chan3<br>R RX<br>err_ko | Chan2<br>R RX<br>err_of | Chan2<br>R RX<br>err_to | Chan2<br>R RX<br>err_rx | Chan2<br>R RX<br>err_ko | Chan1<br>R RX<br>err_of | Chan1<br>R RX<br>err_to | Chan1<br>R RX<br>err_rx | Chan1<br>R RX<br>err_ko | Chan0<br>R RX<br>err_of | Chan0<br>R RX<br>err_to | Chan0<br>R RX<br>err_rx | Chan0<br>R RX<br>err_ko |
| ro                      |
| 15                      | 14                      | 13                      | 12                      | 11                      | 10                      | 9                       | 8                       | 7                       | 6                       | 5                       | 4                       | 3                       | 2                       | 1                       | 0                       |
| Chan3<br>L RX<br>err_of | Chan3<br>L RX<br>err_to | Chan3<br>L RX<br>err_rx | Chan3<br>L RX<br>err_ko | Chan2<br>L RX<br>err_of | Chan2<br>L RX<br>err_to | Chan2<br>L RX<br>err_rx | Chan2<br>L RX<br>err_ko | Chan1<br>L RX<br>err_of | Chan1<br>L RX<br>err_to | Chan1<br>L RX<br>err_rx | Chan1<br>L RX<br>err_ko | Chan0<br>L RX<br>err_of | Chan0<br>L RX<br>err_to | Chan0<br>L RX<br>err_rx | Chan0<br>L RX<br>err_ko |
| ro                      |

The user can read the error contributors for Left and Right 4 channels. See [3].



### 2.13 HSSAER RX MSK register (HSSAER\_RX\_MSK\_REG)

This is the HSSAER Rx mask register.

| HSSA                    | ER_RX_                  | _MSK_F                  | REG (HI                 | PUCore                  | Base +                  | 0x3C)                   |                         |                         |                         |                         |                         | Rese                    | t Value:                | 0x000                   | 00000                   |
|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|
| 31                      | 30                      | 29                      | 28                      | 27                      | 26                      | 25                      | 24                      | 23                      | 22                      | 21                      | 20                      | 19                      | 18                      | 17                      | 16                      |
| Chan3<br>R RX<br>err_of | Chan3<br>R RX<br>err_to | Chan3<br>R RX<br>err_rx | Chan3<br>R RX<br>err_ko | Chan2<br>R RX<br>err_of | Chan2<br>R RX<br>err_to | Chan2<br>R RX<br>err_rx | Chan2<br>R RX<br>err_ko | Chan1<br>R RX<br>err_of | Chan1<br>R RX<br>err_to | Chan1<br>R RX<br>err_rx | Chan1<br>R RX<br>err_ko | Chan0<br>R RX<br>err_of | Chan0<br>R RX<br>err_to | Chan0<br>R RX<br>err_rx | Chan0<br>R RX<br>err_ko |
| rw                      |
| 15                      | 14                      | 13                      | 12                      | 11                      | 10                      | 9                       | 8                       | 7                       | 6                       | 5                       | 4                       | 3                       | 2                       | 1                       | 0                       |
| Chan3<br>L RX<br>err_of | Chan3<br>L RX<br>err_to | Chan3<br>L RX<br>err_rx | Chan3<br>L RX<br>err_ko | Chan2<br>L RX<br>err_of | Chan2<br>L RX<br>err_to | Chan2<br>L RX<br>err_rx | Chan2<br>L RX<br>err_ko | Chan1<br>L RX<br>err_of | Chan1<br>L RX<br>err_to | Chan1<br>L RX<br>err_rx | Chan1<br>L RX<br>err_ko | Chan0<br>L RX<br>err_of | Chan0<br>L RX<br>err_to | Chan0<br>L RX<br>err_rx | Chan0<br>L RX<br>err_ko |
| rw                      |

The user can mask (writing 0) or not (writing 1) the corresponding contributors of error register. See [3].



rw

rw

rw

rw

### 2.14 RX Control register (RX\_CTRL\_REG)

This is the HSSAER Left and Right Rx control register.

| RX_C | TRL_RE | G (HPL | JCore B | ase + (      | 0x40)        |              |              |    |      |       |    | Rese          | t Value:   | 0x000       | 00000        |
|------|--------|--------|---------|--------------|--------------|--------------|--------------|----|------|-------|----|---------------|------------|-------------|--------------|
| 31   | 30     | 29     | 28      | 27           | 26           | 25           | 24           | 23 | 22   | 21    | 20 | 19            | 18         | 17          | 16           |
|      | Dana   |        |         | RRX          | HSSAEF       | R Channe     | el En        |    | Dana |       |    | RRX           | RRX        | RRX         | RRX<br>HSSAE |
|      | Rese   | rvea   |         | Channel<br>3 | Channel<br>2 | Channel<br>1 | Channel<br>0 |    | Rese | ervea |    | SpNNI<br>nkEn | GTP<br>En  | PAER<br>En  | R<br>En      |
|      |        |        |         |              | r            | W            |              |    |      |       |    | rw            | rw         | rw          | rw           |
| 15   | 14     | 13     | 12      | 11           | 10           | 9            | 8            | 7  | 6    | 5     | 4  | 3             | 2          | 1           | 0            |
| 13   | 17     | 13     | 12      | 11           | 10           | J            | O            | /  | 0    | J     | Т  | J             |            | 1           | 0            |
|      | Rese   | nyod   |         | LRX          | HSSAER       | R Channe     | el En        |    | Rese | nvod  |    | LRX<br>SpNNI  | LRX<br>GTP | LRX<br>PAER | LRX<br>HSSAE |
|      | Rese   | rveu   |         | Channel<br>3 | Channel<br>2 | Channel<br>1 | Channel<br>0 |    | Rese | riveu |    | nkEn          | En         | En          | R<br>En      |

#### Where:

- LRX HSSAER Enable
  - When '0', the Left HSSAER interface is not enabled

rw

- When '1', the Left HSSAER interface is enabled
- LRX PAER Enable
  - When '0', the Left PAER interface is not enabled
  - When '1', the Left PAER interface is enabled
- LRX GTP Enable
  - o When '0', the Left GTP interface is not enabled
  - When '1', the Left GTP interface is enabled
- LRX SpNNlnk Enable
  - When '0', the Left SpiNNlink interface is not enabled
  - o When '1', the Left SpiNNlink interface is enabled
- LRX HSSAER Channel Enable
  - Write 1 in the corresponding channel to enable it
- RRX HSSAER Enable
  - When '0', the Right HSSAER interface is not enabled
  - When '1', the Right HSSAER interface is enabled
- RRX PAER Enable
  - When '0', the Right PAER interface is not enabled
  - When '1', the Right PAER interface is enabled
- RRX GTP Enable
  - When '0', the Right GTP interface is not enabled
  - When '1', the Right GTP interface is enabled
- RRX SpNNInk Enable
  - o When '0', the Right SpiNNlink interface is not enabled
  - When '1', the Right SpiNNlink interface is enabled
- RRX HSSAER Channel Enable
  - o Write 1 in the corresponding channel to enable it



### 2.15 TX Control register (TX\_CTRL\_REG)

This is the HSSAER Tx control register.

| TX_C                        | TRL_RE                      | G (HPL | JCore B | ase + 0      | )x44)        |              |              | Reset ' | Value: 0     | x00000        | 0000               |               |           |                       |             |
|-----------------------------|-----------------------------|--------|---------|--------------|--------------|--------------|--------------|---------|--------------|---------------|--------------------|---------------|-----------|-----------------------|-------------|
| 31                          | 30                          | 29     | 28      | 27           | 26           | 25           | 24           | 23      | 22           | 21            | 20                 | 19            | 18        | 17                    | 16          |
|                             |                             |        |         |              |              |              |              |         |              |               | estamp<br>election |               |           | ig resyn<br>Selection |             |
|                             |                             |        |         |              |              |              |              |         |              |               |                    |               | r         | W                     |             |
| 15                          | 14                          | 13     | 12      | 11           | 10           | 9            | 8            | 7       | 6            | 5             | 4                  | 3             | 2         | 1                     | 0           |
| TX<br>timeout               | TX<br>Timing                | ту т   | iming   | TX           | HSSAER       | Channe       | l En         |         | Tx<br>Dest   | Tx<br>Dest    | Tx<br>Dest         | TX            | TX        | TX                    | TX<br>HSSAE |
| counter<br>rearm/s<br>tatus | resync<br>retrig/<br>status |        | ode     | Channel<br>3 | Channel<br>2 | Channel<br>1 | Channel<br>0 |         | Switch<br>En | Switch<br>(1) | Switch<br>(0)      | SpNNI<br>nkEn | GTP<br>En | PAER<br>En            | R<br>En     |
| rw                          | rw                          | r      | W       |              | r            | W            |              |         | rw           | rw            | rw                 | rw            | rw        | rw                    | rw          |

#### Where:

- TX Destination Switch Enable
  - When '0' the message is routed according to its two MSB bits:
    - 00 => the packet is sent to the parallel AER interface
    - 01 => the packet is sent to the HSSAER interface
    - 10 => the packet is sent to the SpiNNlink interface ------ it was: GTP driver interface
    - 11 => the packet is sent to all the interfaces: it is acknowledged
    - When '1' the message is routed according to TxDestSwitch(1:0)

Note: tied to '0' if IP doesn't have any TX interface

- TX Destination Switch
  - o if TX Destination Switch Enable = '1',

wher

- 00 => the packet is sent to the parallel AER interface
  - 01 => the packet is sent to the HSSAER interface
  - 10 => the packet is sent to the SpiNNlink interface ----- it was: GTP driver interface
  - 11 => the packet is sent to all the interfaces: it is acknowledged
- if TX Destination Switch Enable = '0', it doesn't have effect

Note: tied to '0' if IP doesn't have any TX interface

- TX HSSAER Enable
  - When '0', the HSSAER interface is not enabled
  - When '1', the HSSAER interface is enabled
- TX PAER Enable
  - o When '0', the PAER interface is not enabled
  - When '1', the PAER interface is enabled
- TX GTP Enable
  - o When '0', the GTP interface is not enabled
  - o When '1', the GTP interface is enabled
- TX SpiNNlink Enable
  - When '0', the SpiNNlink interface is not enabled
  - $\circ\quad$  When '1', the SpiNNlink interface is enabled
- TX HSSAER Channel Enable
  - Write 1 in the corresponding channel to enable it



- TX Timing Mode
  - o 00 : Delta Time mode: timestamp provided with data is the Delta Time since the last
  - o 01: ASAP Mode: timestam is ignored, and events are sent as-soon-as-possible
  - 10 : Absolute Time Mode: timestamp provided with data is "absolute"
  - 11 : Available for future use (if selected now, TX is stopped)
- TX Timing resync Retrig/Status
  - When read, it reports the Status of Resynchronization:
    - 1 = TX Timer is ready for resynchronization with new data;
    - 0 = TX Timer is evolving by its own;
  - Writing "1" force the TX timer to be ready for resynchronization, regardless timeout was or not reached;
  - Writing "0" does not have any effect.
- TX Timeout counter Rearm/Status
  - When read, it reports the Status of Timeout Counter:
    - 1 = Counting (it means that last event was sent and internal TX FIFO is void)
    - 0 = Stopped (it means that TX engine is processing data);
  - Writing "1" force a rearming of Timeout Counter (like an event was sent);
  - Writing "0" does not have any effect.
- TX Timing resync timeout selection
  - It permits to select the timeout value for a resynchronisation or disable the timeout counter
    - 0 = 1 ms
    - 1 = 5 ms
    - 2 =10 ms
    - 3 = 50 ms
    - 4 = 100 ms
    - 5 = 500 ms
    - 6 = 1 s
    - 7 = 2.5 s
    - 8 = 5 s
    - 9 = 10 s
    - A = 25 s
    - B = 50 s
    - C = 100 s (1m 40s)
    - D = 250 s (4m 10s)
    - E = 500 s (8m 20)
    - F = Timer disabled
- TX Timestamp Mask Selection
  - o It permits to select a Mask for TX internal Timestamp (be sure that it is big enough to contain the maximum delay between events, and lower than the mask of Data Timestamp)
    - $0 = 0 \times 000 \text{ FFFF} (20 \text{ bits})$
    - 1 = 0x00FFFFFF (24 bits)
    - 2 = 0x0FFFFFFF (28 bits)
    - 3 = 0xFFFFFFF (32 bits)



### 2.16 RX PAER Configuration register (RX\_PAER\_CFNG\_REG)

This is the RX PAER configuration register.

| RX_P | AER_C | NG_RE | G (HPL  | JCore B | ase + ( | 0x48) |    |    |         |    |                               | Rese     | t Value: | 0x020                              | 00100                              |
|------|-------|-------|---------|---------|---------|-------|----|----|---------|----|-------------------------------|----------|----------|------------------------------------|------------------------------------|
| 31   | 30    | 29    | 28      | 27      | 26      | 25    | 24 | 23 | 22      | 21 | 20                            | 19       | 18       | 17                                 | 16                                 |
|      |       | RXPA  | ER Ack  | release | Delay   |       |    |    |         | RX | PAER Ac                       | k Set De | elay     |                                    |                                    |
|      |       |       | r       | w       |         |       |    |    |         |    | rv                            | V        |          |                                    |                                    |
| 15   | 14    | 13    | 12      | 11      | 10      | 9     | 8  | 7  | 6       | 5  | 4                             | 3        | 2        | 1                                  | 0                                  |
|      |       | RXPA  | ER Data | Sample  | Delay   |       |    |    | Reserve | d  | RXPAER<br>ignore<br>Fifo Full | Rese     | erved    | RXPAE<br>R<br>Ack<br>Active<br>Lvl | RXPAE<br>R<br>Req<br>Active<br>Lvl |
|      |       |       | r       | W       |         |       |    |    |         |    | rw                            |          |          | rw                                 | rw                                 |

#### Where:

- RXPAER Req Active level
  - o When '0', the Request signal is active low
  - o When '1', the Request signal is active high
- RXPAER Ack Active level
  - When '0', the Acknowledge signal is active low
  - When '1', the Acknowledge signal is active high
- RX PAER ignore FIfo Full
  - When '0', the Fifo Full stops the acknowledge signal
  - When '1', the Fifo Full doesn't stop the acknowledge signal by acknowledging the request
- RXPAER Data Sample Delay
  - $\circ\quad$  This is the number of system clock used to sample the PAER address.
- RXPAER Ack Set Delay
  - o This is the number of system clock used to set the ACK signal after that the request becomes active.
- RXPAER Ack Release Delay
  - o This is the number of system clock used to release the ACK signal after that the request becomes active.

Please note that RXPAER Data Sample Delay, RXPAER Ack Set Delay and RXPAER Ack Release Delay must be different in values.

Please note that this register must be written before enabling the interface in RX Control register (RX\_CTRL\_REG) and/or AUXiliary RX Control register (AUX\_RX\_CTRL\_REG)



### 2.17 TX PAER Configuration register (TX\_PAER\_CFNG\_REG)

This is the TX PAER configuration register.

| TX_PA | AER_CF | NG_RE | G (HPU | Core B | ase + 0 | x4C) |       |       |    |    |    | Rese | t Value: | 0x000                              | 00000                              |
|-------|--------|-------|--------|--------|---------|------|-------|-------|----|----|----|------|----------|------------------------------------|------------------------------------|
| 31    | 30     | 29    | 28     | 27     | 26      | 25   | 24    | 23    | 22 | 21 | 20 | 19   | 18       | 17                                 | 16                                 |
|       |        |       |        |        |         |      | Rese  | erved |    |    |    |      |          |                                    |                                    |
|       |        |       |        |        |         |      |       |       |    |    |    |      |          |                                    |                                    |
| 15    | 14     | 13    | 12     | 11     | 10      | 9    | 8     | 7     | 6  | 5  | 4  | 3    | 2        | 1                                  | 0                                  |
|       |        |       |        |        |         | Rese | erved |       |    |    |    |      |          | TXPAE<br>R<br>Ack<br>Active<br>Lvl | TXPAE<br>R<br>Req<br>Active<br>Lvl |
|       |        |       |        |        |         |      |       |       |    |    |    |      |          | rw.                                | r\A/                               |

#### Where:

- TXPAER Req Active level
  - When '0', the Request signal is active low
  - o When '1', the Request signal is active high
- TXPAER Ack Active level
  - When '0', the Acknowledge signal is active low
  - When '1', the Acknowledge signal is active high

Please note that this register must be set before to enabling the PAER interface (i.e.: before writing the TX Control register (TX\_CTRL\_REG)



### 2.18 IP Configuration register (IP CFNG REG)

This is the HPUCore configuration register. It shows how the HPUCore has been implemented in terms of features.

| IP_CF | NG_RE | G (HPL | JCore B | Base + C | )x50) |    |      |       |    |    |    | Rese | t Value: | 0x000 | 0???? |
|-------|-------|--------|---------|----------|-------|----|------|-------|----|----|----|------|----------|-------|-------|
| 31    | 30    | 29     | 28      | 27       | 26    | 25 | 24   | 23    | 22 | 21 | 20 | 19   | 18       | 17    | 16    |
|       |       |        |         |          |       |    | Rese | erved |    |    |    |      |          |       |       |

| Reserved | TX HSSAER<br>#channels -1 | HAS<br>TX<br>SpNNI<br>nk | HAS<br>TX<br>GTP | Has<br>TX<br>PAER | Has<br>TX<br>HSSAE<br>R | Reserved | RX HSSAER<br>#channels -1 | HAS<br>RX<br>SpNNI<br>nk | HAS<br>RX<br>GTP | Has<br>RX<br>PAER | Has<br>RX<br>HSSAE<br>R |
|----------|---------------------------|--------------------------|------------------|-------------------|-------------------------|----------|---------------------------|--------------------------|------------------|-------------------|-------------------------|
|          |                           |                          |                  |                   |                         |          |                           |                          | ro               | ro                | ro                      |

#### Where:

15

Has RX HSSAER

14

13

12

When '0', the IP doesn't have the RX HSSAER I/f

10

When '0', the IP has the RX HSSAER I/f

11

- Has RX PAER
  - When '0', the IP doesn't have the RX PAER I/f
  - When '0', the IP has the RX PAER I/f 0
- Has RX GTP
  - When '0', the IP doesn't have the RX GTP I/f
  - When '0', the IP has the RX GTP I/f
- Has RX SpiNNlink
  - When '0', the IP doesn't have the RX SpiNNlink I/f
  - When '0', the IP has the RX SpiNNlink I/f
- RX HSSAER #channels -1
  - This shows the number of channels of RX HSSAER I/f. For instance, if it is 2'b10, it means that the RX HSSAER interface has 3 channels
- Has TX HSSAER
  - When '0', the IP doesn't have the TX HSSAER I/f
  - When '0', the IP has the TX HSSAER I/f 0
- Has TX PAER
  - When '0', the IP doesn't have the TX PAER I/f
  - When '0', the IP has the TX PAER I/f 0
- Has TX GTP
  - When '0', the IP doesn't have the TX GTP I/f
  - When '0', the IP has the TX GTP I/f
- Has TX SpiNNlink
  - When '0', the IP doesn't have the TX SpiNNlink I/f
  - When '0', the IP has the TX SpiNNlink I/f
- RX HSSAER #channels -1
  - This shows the number of channels of RX HSSAER I/f. For instance, if it is 2'b10, it means that the RX HSSAER interface has 3 channels



### 2.19 Fifo Threshold register (FIFO\_THRSH\_REG)

This register contains the number of elements of the INFIFO after which the "RXFIFO > THRS" of the IRQ Register (IRQ\_REG) bit goes high.

| FIFO_ | THRSH | I_REG ( | HPUCo | re Base | + 0x5 | 4) |    |    |      |          |      | Rese | t Value: | 0x000 | 00000 |
|-------|-------|---------|-------|---------|-------|----|----|----|------|----------|------|------|----------|-------|-------|
| 31    | 30    | 29      | 28    | 27      | 26    | 25 | 24 | 23 | 22   | 21       | 20   | 19   | 18       | 17    | 16    |
|       |       |         |       |         |       |    |    |    |      |          |      |      |          |       |       |
|       |       |         |       |         |       |    |    |    |      |          |      |      |          |       |       |
|       |       |         |       |         |       |    |    |    | _    |          |      | _    |          |       |       |
| 15    | 14    | 13      | 12    | 11      | 10    | 9  | 8  | 7  | 6    | 5        | 4    | 3    | 2        | 1     | 0     |
|       |       |         |       |         |       |    |    |    | Thre | eshold v | alue |      |          |       |       |

r/w



## 2.20 LoopBack AUX Configuration (LPBK\_AUX\_CNFG\_REG)

This register contains the configuration for the AUX interface loopback.

| LPBK_    | LPBK_AUX_CNFG_REG (HPUCore Base + 0x58)  Reset Value: 0x00000000 |    |    |     |                        |    |    |     |                        |    |    |     |                        |    | 00000 |  |
|----------|------------------------------------------------------------------|----|----|-----|------------------------|----|----|-----|------------------------|----|----|-----|------------------------|----|-------|--|
| 31       | 30                                                               | 29 | 28 | 27  | 26                     | 25 | 24 | 23  | 22                     | 21 | 20 | 19  | 18                     | 17 | 16    |  |
| Reserved |                                                                  |    |    |     |                        |    |    |     |                        |    |    |     |                        |    |       |  |
|          |                                                                  |    |    |     |                        |    |    |     |                        |    |    |     |                        |    |       |  |
| 15       | 14                                                               | 13 | 12 | 11  | 10                     | 9  | 8  | 7   | 6                      | 5  | 4  | 3   | 2                      | 1  | 0     |  |
| AUX      | AUX RX chan 3 LPB cnfg                                           |    |    |     | AUX RX chan 2 LPB cnfg |    |    |     | AUX RX chan 1 LPB cnfg |    |    |     | AUX RX chan 0 LPB cnfg |    |       |  |
| r/w      |                                                                  |    |    | r/w |                        |    |    | r/w |                        |    |    | r/w |                        |    |       |  |

The register is used in debug to test the connection. For further details, look at the RTL code.



## 2.21 Identification register (ID\_REG)

This register contains the ID of the NeuElab.

| ID_REG (HPUCore Base + 0x5C) Reset Value: 48505534 |    |    |    |    |    |    |    |     |     |       |    |     |    |       |    |  |  |  |
|----------------------------------------------------|----|----|----|----|----|----|----|-----|-----|-------|----|-----|----|-------|----|--|--|--|
| 31                                                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21    | 20 | 19  | 18 | 17    | 16 |  |  |  |
|                                                    | Н  |    |    |    |    |    |    |     |     | P     |    |     |    |       |    |  |  |  |
| r/o                                                |    |    |    |    |    |    |    |     | r/o |       |    |     |    |       |    |  |  |  |
| 15                                                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6   | 5     | 4  | 3   | 2  | 1     | 0  |  |  |  |
|                                                    | U  |    |    |    |    |    |    |     |     | Major |    |     |    | Minor |    |  |  |  |
| r/o                                                |    |    |    |    |    |    |    | r/o |     |       |    | r/o |    |       |    |  |  |  |

Minor = 4;

Major = 3;



#### 2.22 AUXiliary RX Control register (AUX RX CTRL REG)

This is the Auxiliary Rx control register.

| AUX_I | RX_CTF | RL_REG | (HPUC | ore Ba | se + 0x | (60) |      |       |    |    |    | Rese | t Value: | 0x0000 | 00000 |
|-------|--------|--------|-------|--------|---------|------|------|-------|----|----|----|------|----------|--------|-------|
| 31    | 30     | 29     | 28    | 27     | 26      | 25   | 24   | 23    | 22 | 21 | 20 | 19   | 18       | 17     | 16    |
|       |        |        |       |        |         |      | Rese | erved |    |    |    |      |          |        |       |

| 15 | 14   | 13    | 12 | 11  | 10                | 9       | 8     | 7 | 6    | 5     | 4 | 3              | 2          | 1           | 0                 |
|----|------|-------|----|-----|-------------------|---------|-------|---|------|-------|---|----------------|------------|-------------|-------------------|
|    | Rese | erved |    | AUX | HSSAEF<br>Channel | Channel | el En |   | Rese | erved |   | AuxRX<br>SpNNI | AUX<br>GTP | AUX<br>PAER | AUX<br>HSSAE<br>R |
|    |      |       |    | 3   | 2                 | 1       | 0     |   |      |       |   | nkEn           | En         | En          | En                |
|    |      |       |    |     | r                 | W       |       |   |      |       |   |                | rw         | rw          | rw                |

#### Where:

- AUX HSSAER Enable
  - When '0', the AUX HSSAER interface is not enabled
  - o When '1', the AUX HSSAER interface is enabled
- AUX PAER Enable
  - o When '0', the AUX PAER interface is not enabled
  - When '1', the AUX PAER interface is enabled
- AUX GTP Enable
  - When '0', the AUX GTP interface is not enabled
  - When '1', the AUX GTP interface is enabled
- AUX SpiNNlink Enable
  - When '0', the AUX SpiNNlink interface is not enabled
  - When '1', the AUX SpiNNlink interface is enabled
- AUX HSSAER Channel Enable
  - o Write 1 in the corresponding channel to enable it



### 2.23 HSSAER AUX RX Error register (HSSAER\_AUX\_RX\_ERR\_REG)

This is the HSSAER Rx error register.

| HSSA                         | ER_AUX                       | K_RX_E                       | RR_RE                        | G (HPU                       | Core B                       | ase + 0                      | )x64)                        |                              |                              |                              |                              | Rese                         | t Value:                     | 0x0000                       | 00000                        |
|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|
| 31                           | 30                           | 29                           | 28                           | 27                           | 26                           | 25                           | 24                           | 23                           | 22                           | 21                           | 20                           | 19                           | 18                           | 17                           | 16                           |
|                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |
|                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |
|                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |                              |
| 15                           | 14                           | 13                           | 12                           | 11                           | 10                           | 9                            | 8                            | 7                            | 6                            | 5                            | 4                            | 3                            | 2                            | 1                            | 0                            |
| Chan3<br>AUX<br>RX<br>err_of | Chan3<br>AUX<br>RX<br>err_to | Chan3<br>AUX<br>RX<br>err_rx | Chan3<br>AUX<br>RX<br>err_ko | Chan2<br>AUX<br>RX<br>err_of | Chan2<br>AUX<br>RX<br>err_to | Chan2<br>AUX<br>RX<br>err_rx | Chan2<br>AUX<br>RX<br>err_ko | Chan1<br>AUX<br>RX<br>err_of | Chan1<br>AUX<br>RX<br>err_to | Chan1<br>AUX<br>RX<br>err_rx | Chan1<br>AUX<br>RX<br>err_ko | Chan0<br>AUX<br>RX<br>err_of | Chan0<br>AUX<br>RX<br>err_to | Chan0<br>AUX<br>RX<br>err_rx | Chan0<br>AUX<br>RX<br>err_ko |
| ro.                          | ro                           |

The user can read the error contributors for the 4 channels of the AUX interface. See [3].



### 2.24 HSSAER AUX RX MSK register (HSSAER\_AUX\_RX\_MSK\_REG)

This is the HSSAER AUX Rx mask register.

| H | ISSAI        | ER_AUX       | K_RX_N       | 1SK_RE       | G (HPL       | JCore B      | ase + (      | 0x68)        |              |              |              |              | Rese         | t Value:     | 0x000        | 00000        |
|---|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
|   | 31           | 30           | 29           | 28           | 27           | 26           | 25           | 24           | 23           | 22           | 21           | 20           | 19           | 18           | 17           | 16           |
|   |              |              |              |              |              |              |              |              |              |              |              |              |              |              |              |              |
|   |              | I.           | I.           | I.           |              | I.           |              | I.           | I.           |              |              |              | I.           |              | I.           |              |
|   |              |              |              |              |              |              |              |              |              |              |              |              |              |              |              |              |
|   | 15           | 14           | 13           | 12           | 11           | 10           | 9            | 8            | 7            | 6            | 5            | 4            | 3            | 2            | 1            | 0            |
|   | Chan3<br>AUX | Chan3<br>AUX | Chan3<br>AUX | Chan3<br>AUX | Chan2<br>AUX | Chan2<br>AUX | Chan2<br>AUX | Chan2<br>AUX | Chan1<br>AUX | Chan1<br>AUX | Chan1<br>AUX | Chan1<br>AUX | Chan0<br>AUX | Chan0<br>AUX | Chan0<br>AUX | Chan0<br>AUX |
| 6 | RX<br>err_of | RX<br>err_to | RX<br>err_rx | RX<br>err_ko |
|   | rw           |

The user can mask (writing 0) or not (writing 1) the corresponding contributors of error register. See [3].



### 2.25 Aux Error counter threshold register (HSSAER\_AUX\_RX\_ERR\_THR\_REG)

This is register is used for setting the threshold of the AUX Rx counter error.

As soon as the number of the corresponding error overcome the threshold here set, the interrupt related will be raised if opportunely masked.

| HSSA | ER_AUX | X_RX_E | RR_TH     | R_REG    | (HPUC | ore Ba | se + 0x | 6C) |    |     |           | Rese     | t Value: | 0x101 | 01010 |
|------|--------|--------|-----------|----------|-------|--------|---------|-----|----|-----|-----------|----------|----------|-------|-------|
| 31   | 30     | 29     | 28        | 27       | 26    | 25     | 24      | 23  | 22 | 21  | 20        | 19       | 18       | 17    | 16    |
|      |        | Nun    | nber of A | AUX of e | error |        |         |     |    | Nur | nber of A | AUX to e | error    |       |       |
|      |        |        | r/        | W        |       |        |         | ·   |    |     | r/        | W        |          |       |       |
| 15   | 14     | 13     | 12        | 11       | 10    | 9      | 8       | 7   | 6  | 5   | 4         | 3        | 2        | 1     | 0     |
|      |        | Nun    | nber of A | AUX rx e | error |        |         |     |    | Num | ber of A  | UX ko e  | rrors    |       |       |
|      |        |        | r/        | w        |       |        |         |     |    |     | r/        | W        |          |       |       |

- Number of AUX ko errors
  - o The number of ko errors which, if overcome, can raise an interrupt
- Number of AUX rx errors
  - o The number of rx errors which, if overcome, can raise an interrupt
- Number of AUX to errors
  - o The number of to errors which, if overcome, can raise an interrupt
- Number of AUX of errors
  - o The number of of errors which, if overcome, can raise an interrupt



r/c

### 2.26 Aux Error counter CH0 register (HSSAER\_AUX\_RX\_ERR\_CH0\_REG)

This is register is used to read the number of errors occurred in  $\mbox{HSSAER}$  AUX channel 0 lines.

Reading this register we also clear it.

| HSSA | ER_AUX | K_RX_E | RR_CH     | 0_REG    | (HPUC | ore Ba | se + 0x | 70) |    |     |           | Rese     | t Value: | 0x000 | 00000 |
|------|--------|--------|-----------|----------|-------|--------|---------|-----|----|-----|-----------|----------|----------|-------|-------|
| 31   | 30     | 29     | 28        | 27       | 26    | 25     | 24      | 23  | 22 | 21  | 20        | 19       | 18       | 17    | 16    |
|      |        | Nun    | nber of ( | CH0 of e | error |        |         |     |    | Nur | nber of ( | CH0 to 6 | error    |       |       |
|      |        |        | r/        | ′c       |       |        |         |     |    |     | r,        | /c       |          |       |       |
| 15   | 14     | 13     | 12        | 11       | 10    | 9      | 8       | 7   | 6  | 5   | 4         | 3        | 2        | 1     | 0     |
|      |        | Nun    | nber of ( | CH0 rx e | error |        |         |     |    | Num | ber of C  | :H0 ko e | errors   |       |       |

- Number of CH0 ko errors
  - o The number of ko errors

r/c

- Number of CH0 rx errors
  - o The number of rx errors
- Number of CH0 to errors
  - o The number of to errors
- Number of CH0 of errors
  - $\circ \quad \text{ The number of of errors }$



r/c

### 2.27 Aux Error counter CH1 register (HSSAER\_AUX\_RX\_ERR\_CH1\_REG)

This is register is used to read the number of errors occurred in HSSAER AUX channel 1 lines.

Reading this register we also clear it.

| HSSA | ER_AUX | K_RX_E | RR_CH     | 1_REG    | (HPUC | ore Ba | se + 0x | 74) |    |     |           | Rese     | t Value: | 0x000 | 00000 |
|------|--------|--------|-----------|----------|-------|--------|---------|-----|----|-----|-----------|----------|----------|-------|-------|
| 31   | 30     | 29     | 28        | 27       | 26    | 25     | 24      | 23  | 22 | 21  | 20        | 19       | 18       | 17    | 16    |
|      |        | Nun    | nber of ( | CH1 of e | error |        |         |     |    | Nur | nber of ( | CH1 to e | error    |       |       |
|      |        |        | r/        | ′c       |       |        |         |     |    |     | r,        | /c       |          |       |       |
| 15   | 14     | 13     | 12        | 11       | 10    | 9      | 8       | 7   | 6  | 5   | 4         | 3        | 2        | 1     | 0     |
|      |        | Nur    | nber of ( | CH1 rx e | error |        |         |     |    | Num | ber of C  | H1 ko e  | rrors    |       |       |

- Number of CH1 ko errors
  - o The number of ko errors

r/c

- Number of CH1 rx errors
  - o The number of rx errors
- Number of CH1 to errors
  - o The number of to errors
- Number of CH1 of errors
  - $\circ \quad \text{ The number of of errors }$



r/c

### 2.28 Aux Error counter CH2 register (HSSAER\_AUX\_RX\_ERR\_CH2\_REG)

This is register is used to read the number of errors occurred in HSSAER AUX channel 2 lines.

Reading this register we also clear it.

| HSSAI | ER_AUX | C_RX_E | RR_CH     | 2_REG    | (HPUC | ore Ba | se + 0x | 78) |    |     |          | Rese     | t Value: | 0x000 | 00000 |
|-------|--------|--------|-----------|----------|-------|--------|---------|-----|----|-----|----------|----------|----------|-------|-------|
| 31    | 30     | 29     | 28        | 27       | 26    | 25     | 24      | 23  | 22 | 21  | 20       | 19       | 18       | 17    | 16    |
|       |        | Nun    | nber of ( | CH2 of e | error |        |         |     |    | Nur | nber of  | CH2 to e | error    |       |       |
|       |        |        | r/        | 'c       |       |        |         |     |    |     | r,       | /c       |          |       |       |
| 15    | 14     | 13     | 12        | 11       | 10    | 9      | 8       | 7   | 6  | 5   | 4        | 3        | 2        | 1     | 0     |
|       |        | Nun    | nber of ( |          |       |        |         |     |    | Num | ber of C | CH2 ko e |          |       |       |

Number of CH2 ko errors

o The number of ko errors

r/c

• Number of CH2 rx errors

o The number of rx errors

Number of CH2 to errors

o The number of to errors

• Number of CH2 of errors

 $\circ \quad \text{ The number of of errors }$ 



### 2.29 Aux Error counter CH3 register (HSSAER\_AUX\_RX\_ERR\_CH3\_REG)

This is register is used to read the number of errors occurred in HSSAER AUX channel 3 lines.

Reading this register we also clear it.

| HSSA | ER_AUX | C_RX_E | RR_CH     | 3_REG    | (HPUC | ore Bas | se + 0x | 7C) |    |     |          | Rese     | t Value: | 0x000 | 00000 |
|------|--------|--------|-----------|----------|-------|---------|---------|-----|----|-----|----------|----------|----------|-------|-------|
| 31   | 30     | 29     | 28        | 27       | 26    | 25      | 24      | 23  | 22 | 21  | 20       | 19       | 18       | 17    | 16    |
|      |        | Nun    | nber of ( | CH3 of e | error |         |         |     |    | Nun | nber of  | CH3 to e | error    |       |       |
|      |        |        | r/        | 'c       |       |         |         |     |    |     | r,       | /c       |          |       |       |
| 1.5  | 1.4    | 12     | 10        | 1.1      | 10    | 0       | 8       | 7   | 6  | _   | 4        | 2        | 2        | 4     | 0     |
| 15   | 14     | 13     | 12        | 11       | 10    | 9       | 8       | 7   | 6  | 5   | 4        | 3        | 2        | Ι     | 0     |
|      |        | Nun    | nber of ( | CH3 rx e | error |         |         |     |    | Num | ber of C | :H3 ko e | errors   |       |       |

r/c r/c

- Number of CH3 ko errors
  - o The number of ko errors
- Number of CH3 rx errors
  - o The number of rx errors
- Number of CH3 to errors
  - o The number of to errors
- Number of CH3 of errors
  - $\circ \quad \text{ The number of of errors }$



### 2.30 SpiNNlink Start command key (SPNN\_START\_KEY\_REG)

This is register is used to define the Command Key that HPU Core expects to receive from SpiNNaker before starting to transmit Packets to it.

TX Spinnaker Module is in "dump mode" until the Key is received.

| SPNN | _STAR | Γ_KEY_ | REG (H | PUCore |    | Rese     | t Value: | 0x800        | 00000   |     |    |    |    |    |    |
|------|-------|--------|--------|--------|----|----------|----------|--------------|---------|-----|----|----|----|----|----|
| 31   | 30    | 29     | 28     | 27     | 26 | 25       | 24       | 23           | 22      | 21  | 20 | 19 | 18 | 17 | 16 |
|      |       |        |        |        | Va | lue of S | TART Co  | mmand        | Key (MS | SB) |    |    |    |    |    |
|      | r/w   |        |        |        |    |          |          |              |         |     |    |    |    |    |    |
| 15   | 14    | 13     | 12     | 11     | 10 | 9        | 8        | 7            | 6       | 5   | 4  | 3  | 2  | 1  | 0  |
|      |       |        |        |        | Va | lue of S | TART Co  | ommand       | Key (LS | SB) |    |    |    |    |    |
|      |       |        |        |        |    |          | -1       | \\\ <i>I</i> |         |     |    |    |    |    |    |

r/w

Value of START Command Key

**NOTE**: if both SPNN\_START\_KEY\_REG and SPNN\_STOP\_KEY\_REG are set to 0x00000000, the functionality is bypassed and TX interface is allowed to transmit despite of a START command has not be received.



### 2.31 SpiNNlink Stop command key (SPNN\_STOP\_KEY\_REG)

This is register is used to define the Command Key that HPU Core expects to receive from SpiNNaker before stopping to transmit Packets to it.

TX Spinnaker Module is in "dump mode" after the Key is received.

| SPNN | _STAR | Г_КЕҮ_ | REG (H | PUCore |    | Rese      | t Value: | 0x400 | 00000   |    |    |    |    |    |    |
|------|-------|--------|--------|--------|----|-----------|----------|-------|---------|----|----|----|----|----|----|
| 31   | 30    | 29     | 28     | 27     | 26 | 25        | 24       | 23    | 22      | 21 | 20 | 19 | 18 | 17 | 16 |
|      |       |        |        |        | Va | alue of S | STOP Co  | mmand | Key (MS | В) |    |    |    |    |    |
|      | r/w   |        |        |        |    |           |          |       |         |    |    |    |    |    |    |
| 15   | 14    | 13     | 12     | 11     | 10 | 9         | 8        | 7     | 6       | 5  | 4  | 3  | 2  | 1  | 0  |
|      |       |        |        |        | V  | alue of S | STOP Co  | mmand | Key (LS | В) |    |    |    |    |    |
| l-   |       |        |        |        |    |           | -1       | 347   |         |    |    |    |    |    |    |

r/w

Value of STOP Command Key

**NOTE**: if both SPNN\_START\_KEY\_REG and SPNN\_STOP\_KEY\_REG are set to 0x00000000, the functionality is bypassed and TX interface is allowed to transmit despite of a START command has not be received.



### 2.32 SpiNNlink TX Data Mask (SPNN\_TX\_MASK\_REG)

This is register is used to define the mask applied to data that are to be transmitted to SpiNNaker.

The default value is 0x00FFFFFF

| SPNN | _TX_M | ASK_RE | G (HPI | JCore E | Base + ( | 0x88)    |         |       |         |     |    | Res | et Value | : 0x00F | FFFFF |
|------|-------|--------|--------|---------|----------|----------|---------|-------|---------|-----|----|-----|----------|---------|-------|
| 31   | 30    | 29     | 28     | 27      | 26       | 25       | 24      | 23    | 22      | 21  | 20 | 19  | 18       | 17      | 16    |
|      |       |        |        |         | Val      | lue of S | TART Co | mmand | Key (M  | SB) |    |     |          |         |       |
|      | r/w   |        |        |         |          |          |         |       |         |     |    |     |          |         |       |
|      |       |        |        |         |          |          |         |       |         |     |    |     |          |         |       |
| 15   | 14    | 13     | 12     | 11      | 10       | 9        | 8       | 7     | 6       | 5   | 4  | 3   | 2        | 1       | 0     |
|      |       |        |        |         | Va       | lue of S | TART Co | mmand | Key (LS | SB) |    |     |          |         |       |

r/w

• Value of START Command Key



### 2.33 SpiNNlink RX Data Mask (SPNN\_RX\_MASK\_REG)

This is register is used to define the mask applied to data received from SpiNNaker.

Please note: the mask affect only data, and not commands (i.e. START and STOP commands)

The default value is 0x00FFFFFF

| SPNN | PNN_RX_MASK_REG (HPUCore Base + 0x8C) |    |    |    |    |    |    |    |    |    |    |    |    | Reset Value: <b>0x00FFFFF</b> |    |  |  |  |
|------|---------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------|----|--|--|--|
| 31   | 30                                    | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                            | 16 |  |  |  |
|      | Value of STOP Command Key (MSB)       |    |    |    |    |    |    |    |    |    |    |    |    |                               |    |  |  |  |
|      | r/w                                   |    |    |    |    |    |    |    |    |    |    |    |    |                               |    |  |  |  |
|      |                                       |    |    |    |    |    |    |    |    |    |    |    |    |                               |    |  |  |  |
| 15   | 14                                    | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1                             | 0  |  |  |  |
|      | Value of STOP Command Key (LSB)       |    |    |    |    |    |    |    |    |    |    |    |    |                               |    |  |  |  |

r/w

• Value of STOP Command Key



Reset Value: 0x00FFFFFF

key

enable

#### 2.34 SpiNNlink Control Register (SPNN\_CTRL\_REG)

This is register is used to define some specific controls dedicated to SpiNNaker link.

The default value is 0x00000000

| 31 | 30 | 29 | 28           | 2/      | 26 | 25 | 24    | 23                 | 22 | 21 | 20 | 19 | 18 | 1/ | 16    |  |
|----|----|----|--------------|---------|----|----|-------|--------------------|----|----|----|----|----|----|-------|--|
|    |    | R) | $\mathbf{x}$ | SpiNNli | nk |    |       | RX RIGHT SpiNNlink |    |    |    |    |    |    |       |  |
|    |    |    |              |         |    |    | START |                    |    |    |    |    |    |    | START |  |

r/w

key

enable

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

| RX AUX SpiNNlink |  |  |  |  |                                |  | TX SpiNNlink |  |  |  |               |                |                        |  |
|------------------|--|--|--|--|--------------------------------|--|--------------|--|--|--|---------------|----------------|------------------------|--|
|                  |  |  |  |  | START<br>STOP<br>key<br>enable |  |              |  |  |  | Force<br>STOP | Force<br>START | Time<br>out<br>Disable |  |

r/w

• TX SpiNNlink Timeout disable

When a packet transmission is in progress, a timeout counter monitors the activity of acknowledge signal from SpiNnaker, and –if enabled- set the "dump mode" when after 128 clock cycles (1.28 us) there isn't any response.

- When "0" the timeout counter is enabled
- When "1" the timeout counter is disabled
- TX SpiNNlink Force START (Write and Clear bit)
  - When a "1" is wrote, the TX stage is forced to Start operations even if START command has not been received from SpiNNaker. Note that the bit clears itself immediately, and the command acts even if bits 8, 16 or 24 are set to "1".
- TX SpiNNlink Force STOP
  - When a "1" is wrote, the TX stage is forced to Stop operations even if STOP command has not been received from SpiNNaker. Note that the bit clears itself immediately, and the command acts even if bits 8, 16 or 24 are set to "1".
- RX AUX SpiNNlink START/STOP Key Command Enable
  - When "1", RX stage is allowed to recognize START and STOP Commands from SpiNNaker.
- RX RIGHT SpiNNlink START/STOP Key Command Enable
  - When "1", RX stage is allowed to recognize START and STOP Commands from SpiNNaker.
- RX LEFT SpiNNlink START/STOP Key Command Enable
  - When "1", RX stage is allowed to recognize START and STOP Commands from SpiNNaker.



#### 2.35 SpiNNlink Status Register (SPNN\_STATUS\_REG)

This is register is used to report some specific status related to SpiNNaker link.

| SPNN | _RX_M | ASK_RE | G (HPL  | JCore B  | ase + | 0x94)           |                    |              |    |    | Res | et Valu | e: <b>0x00</b>  | FFFFFF      |                     |
|------|-------|--------|---------|----------|-------|-----------------|--------------------|--------------|----|----|-----|---------|-----------------|-------------|---------------------|
| 31   | 30    | 29     | 28      | 27       | 26    | 25              | 24                 | 23           | 22 | 21 | 20  | 19      | 18              | 17          | 16                  |
|      |       | R)     | X LEFT  | SpiNNli  | nk    |                 | RX RIGHT SpiNNlink |              |    |    |     |         |                 |             |                     |
|      |       |        |         |          |       | Parity<br>Error |                    |              |    |    |     |         | Parity<br>Error | Rx<br>Error |                     |
|      |       |        |         |          |       |                 | ı                  | r            |    |    |     |         |                 |             |                     |
| 15   | 14    | 13     | 12      | 11       | 10    | 9               | 8                  | 7            | 6  | 5  | 4   | 3       | 2               | 1           | 0                   |
|      |       | R      | X AUX S | SpiNNlir | ηk    |                 |                    | TX SpiNNlink |    |    |     |         |                 |             |                     |
|      |       |        |         |          |       | Parity<br>Error | Rx<br>Error        |              |    |    |     |         |                 | Offload     | Link<br>Time<br>out |
|      |       |        |         |          |       |                 | ı                  | r            |    |    |     |         |                 |             |                     |

TX SpiNNlink Link Timeout

When a packet transmission is in progress, a timeout counter monitors the activity of acknowledge signal from SpiNnaker, and –if enabled- set the "dump mode" when after 128 clock cycles (1.28 us) there isn't any response.

- When "1" the timeout counter reached the end
- TX SpiNNlink Offload
  - When "1" SpiNNlink is in Offload Dump Mode because START command has not been received/forced or STOP command has been received/forced
- RX AUX SpiNNlink Rx Error
  - o When '0', the Aux SpiNNlink RX is working
  - When '1', the Aux SpiNNlink RX is receiving wrong symbols
- RX AUX SpiNNlink Parity Error
  - When '0', the Aux SpiNNlink RX is working
  - When '1', the Aux SpiNNlink RX is receiving packets with wrong parity
- RX Right SpiNNlink Rx Error
  - o When '0', the Right SpiNNlink RX is working
  - When '1', the Right SpiNNlink RX is receiving wrong symbols
- RX Right SpiNNlink Parity Error
  - When '0', the Right SpiNNlink RX is working
  - o When '1', the Right SpiNNlink RX is receiving packets with wrong parity
- RX Left SpiNNlink Rx Error
  - When '0', the Left SpiNNlink RX is working
  - When '1', the Left SpiNNlink RX is receiving wrong symbols
- RX Left SpiNNlink Parity Error
  - When '0', the Left SpiNNlink RX is working
  - o When '1', the Left SpiNNlink RX is receiving packets with wrong parity



### 2.36 TLAST TIMEOUT Register (TLASTTO\_REG)

This register is used to issue a premature end of an Axistream burst. When the time counted by this register expires and at least a couple of data have been trasferred, a dummy data (0xF0CACC1A) is sent as last data of the burst. In this way we can perform a premature end of an axistream burst. This is useful to decrease the latency in DMA responsiveness.

| TLAST | TLASTTO_REG (HPUCore Base + 0xA0) Reset Value: 0x00010000                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|--------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31    | 30                                                                                         | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|       | Number of clock period to perform a premature Axistream burst end during a "slow" transfer |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       | r/w                                                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |                                                                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15    | 14                                                                                         | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|       | Number of clock period to perform a premature Axistream burst end during a "slow" transfer |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

r/w



### 2.37 TLAST Counter Register (TLASTCNT\_REG)

This register is used to read the number of valid Tlast Axistream events that the HPU has performed.

| TLAST | CNT_R                             | EG (HP | UCore | Base + | 0xA4) |    |    |    |    |    |    | Rese | t Value: | 0x000 | 00000 |
|-------|-----------------------------------|--------|-------|--------|-------|----|----|----|----|----|----|------|----------|-------|-------|
| 31    | 30                                | 29     | 28    | 27     | 26    | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18       | 17    | 16    |
|       | Number of Tlast events in RX Fifo |        |       |        |       |    |    |    |    |    |    |      |          |       |       |
|       | r/o                               |        |       |        |       |    |    |    |    |    |    |      |          |       |       |
|       |                                   |        |       |        |       |    |    |    |    |    |    |      |          |       |       |
| 15    | 14                                | 13     | 12    | 11     | 10    | 9  | 8  | 7  | 6  | 5  | 4  | 3    | 2        | 1     | 0     |
|       | Number of Tlast events in TX Fifo |        |       |        |       |    |    |    |    |    |    |      |          |       |       |

r/o



### 2.38 TData Counter Register (TDATACNT\_REG)

This register is used to read the number of valid Axistream DATA that the HPU has performed.

| TDATA | ACNT_F                           | REG (HF | <b>PUCore</b> | Base + | 0xA8) |    |    |    |    |    |    | Rese | t Value: | 0x000 | 00000 |
|-------|----------------------------------|---------|---------------|--------|-------|----|----|----|----|----|----|------|----------|-------|-------|
| 31    | 30                               | 29      | 28            | 27     | 26    | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18       | 17    | 16    |
|       | Number of TDATA valid in RX Fifo |         |               |        |       |    |    |    |    |    |    |      |          |       |       |
|       | r/o                              |         |               |        |       |    |    |    |    |    |    |      |          |       |       |
|       |                                  |         |               |        |       |    |    |    |    |    |    |      |          |       |       |
| 15    | 14                               | 13      | 12            | 11     | 10    | 9  | 8  | 7  | 6  | 5  | 4  | 3    | 2        | 1     | 0     |
|       | Number of TDATA valid in TX Fifo |         |               |        |       |    |    |    |    |    |    |      |          |       |       |

r/o



### 3 References

- [1] ARM AMBA AXI protocol v2.0
- [2] "Combining the ADS1202 with an FPGA Digital Filter for Current Measurement in Motor Control Applications", Texas Instruments, Application Report SBAA094 June 2003.
- [3] "Asynchronous DC-Free Serial Protocol for Event-Based AER Systems", P. Motto Ros, M. Crepaldi, C. Bartolozzi and D. Demarchi, 2015 IEEE International Conference on Electronics, Circuits, and Systems (ICECS)

### 4 **Appendixes**

#### 4.1 Axistream ASM

